Netty Channel ---AbstractNioByteChannel & AbstractNioMessageChannel源码解析

本文深入剖析了Netty框架中的AbstractNioByteChannel和AbstractNioMessageChannel的源码,包括NioServerSocketChannel和NioSocketChannel的实现细节。重点讲解了在处理写半包情况下的读写操作,如何从SocketChannel高效地将数据传输到ByteBuf中。
摘要由CSDN通过智能技术生成
AbstractNioByteChannel源码解析    
@Override protected void doWrite(ChannelOutboundBuffer in) throws Exception { int writeSpinCount = - 1 ; for (;;) {         // 从当前的消息发送环形数组中弹出一条消息 Object msg = in.current();         // 消息为null,说明所有消息已经发送完成,清除写操作位 if (msg == null ) { // Wrote all messages. clearOpWrite(); break ; }         // 如果msg是ByteBuf类型 if (msg instanceof ByteBuf) { ByteBuf buf = (ByteBuf) msg; int readableBytes = buf.readableBytes();             // 如果消息没有可读字节,则丢弃消息,进行下一次循环 if (readableBytes == 0 ) { in.remove(); continue ; }             // 设置写半包标识 boolean setOpWrite = false ;             // 设置消息是否全部发送标志 boolean done = false ;             // 设置发送的消息总字节数 long flushedAmount = 0 ;             // 获取循环发送次数:是为了当一次发送没有完成时,继续循环发送的次数,设置写半包的最大循环次数的原因是循环发送的时候,             // IO线程会一直进行写操作, 此时IO线程无法处理其他的IO操作,例如读取新的消息或者执行定时任务等;如果网络IO阻塞或者对方接受消息太慢,             // 可能导致线程假死 if (writeSpinCount == - 1 ) { writeSpinCount = config().getWriteSpinCount(); } for ( int i = writeSpinCount - 1 ; i >=
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值