Motivation: If there are no readable bytes, it's unnecessary to go through javaChannel().write().
Modification: If the readableBytes() is zero, then just return. Result: The logic can be easy to understand and a little faster than before.
This commit is contained in:
parent
2ab2e2d6b7
commit
ecf1b558d9
@ -176,6 +176,9 @@ public class NioUdtMessageConnectorChannel extends AbstractNioMessageChannel imp
|
||||
final ByteBuf byteBuf = message.content();
|
||||
|
||||
final int messageSize = byteBuf.readableBytes();
|
||||
if (messageSize == 0) {
|
||||
return true;
|
||||
}
|
||||
|
||||
final long writtenBytes;
|
||||
if (byteBuf.nioBufferCount() == 1) {
|
||||
@ -184,18 +187,13 @@ public class NioUdtMessageConnectorChannel extends AbstractNioMessageChannel imp
|
||||
writtenBytes = javaChannel().write(byteBuf.nioBuffers());
|
||||
}
|
||||
|
||||
// did not write the message
|
||||
if (writtenBytes <= 0 && messageSize > 0) {
|
||||
return false;
|
||||
}
|
||||
|
||||
// wrote message completely
|
||||
if (writtenBytes != messageSize) {
|
||||
if (writtenBytes > 0 && writtenBytes != messageSize) {
|
||||
throw new Error(
|
||||
"Provider error: failed to write message. Provider library should be upgraded.");
|
||||
}
|
||||
|
||||
return true;
|
||||
return writtenBytes > 0;
|
||||
}
|
||||
|
||||
@Override
|
||||
|
Loading…
x
Reference in New Issue
Block a user