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 >=