NioUdpWorker.read() now honors buffer factory's default byte order

This commit is contained in:
Trustin Lee 2009-06-11 07:14:40 +00:00
parent fa3eb52f4e
commit 8f4e0b524c

View File

@ -44,6 +44,7 @@ import java.util.concurrent.locks.ReadWriteLock;
import java.util.concurrent.locks.ReentrantReadWriteLock; import java.util.concurrent.locks.ReentrantReadWriteLock;
import org.jboss.netty.buffer.ChannelBuffer; import org.jboss.netty.buffer.ChannelBuffer;
import org.jboss.netty.buffer.ChannelBufferFactory;
import org.jboss.netty.buffer.ChannelBuffers; import org.jboss.netty.buffer.ChannelBuffers;
import org.jboss.netty.channel.Channel; import org.jboss.netty.channel.Channel;
import org.jboss.netty.channel.ChannelException; import org.jboss.netty.channel.ChannelException;
@ -214,7 +215,6 @@ class NioUdpWorker implements Runnable {
for (;;) { for (;;) {
wakenUp.set(false); wakenUp.set(false);
//
if (NioProviderMetadata.CONSTRAINT_LEVEL != 0) { if (NioProviderMetadata.CONSTRAINT_LEVEL != 0) {
selectorGuard.writeLock().lock(); selectorGuard.writeLock().lock();
// This empty synchronization block prevents the selector from acquiring its lock. // This empty synchronization block prevents the selector from acquiring its lock.
@ -350,14 +350,15 @@ class NioUdpWorker implements Runnable {
final NioDatagramChannel channel = (NioDatagramChannel) key.attachment(); final NioDatagramChannel channel = (NioDatagramChannel) key.attachment();
ReceiveBufferSizePredictor predictor = ReceiveBufferSizePredictor predictor =
channel.getConfig().getReceiveBufferSizePredictor(); channel.getConfig().getReceiveBufferSizePredictor();
final ChannelBufferFactory bufferFactory = channel.getConfig().getBufferFactory();
final DatagramChannel nioChannel = (DatagramChannel) key.channel(); final DatagramChannel nioChannel = (DatagramChannel) key.channel();
// Allocating a non-direct buffer with a max udp packge size. // Allocating a non-direct buffer with a max udp packge size.
// Would using a direct buffer be more efficient or would this negatively // Would using a direct buffer be more efficient or would this negatively
// effect performance, as direct buffer allocation has a higher upfront cost // effect performance, as direct buffer allocation has a higher upfront cost
// where as a ByteBuffer is heap allocated. // where as a ByteBuffer is heap allocated.
final ByteBuffer byteBuffer = ByteBuffer.allocate(predictor.nextReceiveBufferSize()); final ByteBuffer byteBuffer = ByteBuffer.allocate(
predictor.nextReceiveBufferSize()).order(bufferFactory.getDefaultOrder());
boolean failure = true; boolean failure = true;
SocketAddress remoteAddress = null; SocketAddress remoteAddress = null;
@ -386,8 +387,7 @@ class NioUdpWorker implements Runnable {
.wrappedBuffer(byteBuffer); .wrappedBuffer(byteBuffer);
// Notify the interested parties about the newly arrived message (channelBuffer). // Notify the interested parties about the newly arrived message (channelBuffer).
fireMessageReceived(channel, channelBuffer, fireMessageReceived(channel, channelBuffer, remoteAddress);
remoteAddress);
} }
} }