arimood 2011-12-07 21:22
浏览 329
已采纳

java nio/netty异步io操作问题

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

  • 写回答

2条回答 默认 最新

  • 关注

    大致是这样:

    write() 之后并不直接写数据, 而是将数据写入一个队列, 然后返回. 由worker线程取出, 执行写操作, 成功后发送事件, 也就调用了你的那个 Listener

    所以doSomething() 也是在worker线程执行的.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 C#算法问题, 不知道怎么处理这个数据的转换
  • ¥15 YoloV5 第三方库的版本对照问题
  • ¥15 请完成下列相关问题!
  • ¥15 drone 推送镜像时候 purge: true 推送完毕后没有删除对应的镜像,手动拷贝到服务器执行结果正确在样才能让指令自动执行成功删除对应镜像,如何解决?
  • ¥15 求daily translation(DT)偏差订正方法的代码
  • ¥15 js调用html页面需要隐藏某个按钮
  • ¥15 ads仿真结果在圆图上是怎么读数的
  • ¥20 Cotex M3的调试和程序执行方式是什么样的?
  • ¥20 java项目连接sqlserver时报ssl相关错误
  • ¥15 一道python难题3