最近学习netty遇到一个问题:netty下的IO操作时异步的,比如执行channel.write()马上返回一个ChannelFuture,假如我要在write()写完后要执行一些操作doSomething(),一般做法是对ChannelFuture添加监听器ChannelFutureListener,然后在监听器内部覆写operationComplete方法,加入doSomething()即可。我的问题是:
1.执行完异步write()后,是不是有其它线程在实际处理“将数据写出”这个操作呢?(Netty下是Boss线程?)
2.当数据处理完,doSomething()这部分代码应该不是write()操作所属线程来执行的,那是由什么线程运行呢?(Boss线程?)
谢谢阅读,可以的话详细说一下……

java nio/netty异步io操作问题
- 写回答
- 好问题 0 提建议
- 关注问题
- 邀请回答
-
2条回答 默认 最新
- 重口味恋 •上小清新 2011-12-08 11:23关注
大致是这样:
write() 之后并不直接写数据, 而是将数据写入一个队列, 然后返回. 由worker线程取出, 执行写操作, 成功后发送事件, 也就调用了你的那个 Listener
所以doSomething() 也是在worker线程执行的.
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报