diff --git a/transport-sctp/src/main/java/io/netty/channel/sctp/oio/OioSctpChannel.java b/transport-sctp/src/main/java/io/netty/channel/sctp/oio/OioSctpChannel.java index 6416ea4e60..01a79d65ad 100755 --- a/transport-sctp/src/main/java/io/netty/channel/sctp/oio/OioSctpChannel.java +++ b/transport-sctp/src/main/java/io/netty/channel/sctp/oio/OioSctpChannel.java @@ -184,39 +184,32 @@ public class OioSctpChannel extends AbstractOioMessageChannel return readMessages; } - Set reableKeys = readSelector.selectedKeys(); + RecvByteBufAllocator.Handle allocHandle = this.allocHandle; + if (allocHandle == null) { + this.allocHandle = allocHandle = config().getRecvByteBufAllocator().newHandle(); + } + ByteBuf buffer = allocHandle.allocate(config().getAllocator()); + boolean free = true; + try { - for (SelectionKey ignored : reableKeys) { - RecvByteBufAllocator.Handle allocHandle = this.allocHandle; - if (allocHandle == null) { - this.allocHandle = allocHandle = config().getRecvByteBufAllocator().newHandle(); - } - ByteBuf buffer = allocHandle.allocate(config().getAllocator()); - boolean free = true; - - try { - ByteBuffer data = buffer.nioBuffer(buffer.writerIndex(), buffer.writableBytes()); - MessageInfo messageInfo = ch.receive(data, null, notificationHandler); - if (messageInfo == null) { - return readMessages; - } - - data.flip(); - msgs.add(new SctpMessage(messageInfo, buffer.writerIndex(buffer.writerIndex() + data.remaining()))); - free = false; - readMessages ++; - } catch (Throwable cause) { - PlatformDependent.throwException(cause); - } finally { - int bytesRead = buffer.readableBytes(); - allocHandle.record(bytesRead); - if (free) { - buffer.release(); - } - } + ByteBuffer data = buffer.nioBuffer(buffer.writerIndex(), buffer.writableBytes()); + MessageInfo messageInfo = ch.receive(data, null, notificationHandler); + if (messageInfo == null) { + return readMessages; + } + + data.flip(); + msgs.add(new SctpMessage(messageInfo, buffer.writerIndex(buffer.writerIndex() + data.remaining()))); + free = false; + readMessages ++; + } catch (Throwable cause) { + PlatformDependent.throwException(cause); + } finally { + int bytesRead = buffer.readableBytes(); + allocHandle.record(bytesRead); + if (free) { + buffer.release(); } - } finally { - reableKeys.clear(); } return readMessages; }