Pipeline1



public abstract class AbstractNioByteChannel extends AbstractNioChannel 
{
    protected class NioByteUnsafe extends AbstractNIoUnsafe {
     @Override
public final void read() {
final ChannelPipeline pipeline = pipeline();
……
// 读取结果.

byteBuf = allocHandle.allocate(allocator);
……
int localReadamount = doReadBytes(byteBuf);
………
  // dispatch结果到Handler
        pipeline.fireChannelRead(byteBuf);
……
}



public class ChannelInboundHandlerAdapter extends ChannelHandlerAdapter implements ChannelInboundHandler
{

//认的通道激活操作

@Override
public void channelActive(ChannelHandlerContext ctx) throws Exception {
ctx.fireChannelActive();
}

//认的通道读操作
@Override
public void channelRead(ChannelHandlerContext ctx,Object msg) throws Exception {
ctx.fireChannelRead(msg);
}

}



abstract class AbstractChannelHandlerContext extends DefaultAttributeMap implements ChannelHandlerContext 
{

volatile AbstractChannelHandlerContext next;
volatile AbstractChannelHandlerContext prev;

@Override
public ChannelHandlerContext fireChannelRead(final Object msg) {
invokeChannelRead(findContextInbound(),msg);
return this;
}
static void invokeChannelRead(final AbstractChannelHandlerContext next,final Object msg) {
  ……
next.invokeChannelRead(msg);
……
}

private void invokeChannelRead(Object msg) {
  ……
((ChannelInboundHandler) handler()).channelRead(this,msg);
……
}


private AbstractChannelHandlerContext findContextInbound() {
AbstractChannelHandlerContext ctx = this;
do {
ctx = ctx.next;
} while (!ctx.inbound);
return ctx;
}

}


private AbstractChannelHandlerContext findContextoutbound() {    AbstractChannelHandlerContext ctx = this;    do {        ctx = ctx.prev;    } while (!ctx.outbound);    return ctx;}

相关文章

迭代器模式(Iterator)迭代器模式(Iterator)[Cursor]意图...
高性能IO模型浅析服务器端编程经常需要构造高性能的IO模型,...
策略模式(Strategy)策略模式(Strategy)[Policy]意图:定...
访问者模式(Visitor)访问者模式(Visitor)意图:表示一个...
命令模式(Command)命令模式(Command)[Action/Transactio...
生成器模式(Builder)生成器模式(Builder)意图:将一个对...