【发布时间】:2021-03-27 17:21:16
【问题描述】:
将字节写入通道时,这3种方法有什么区别?
在我的例子中,写入这些字节的线程不是属于通道的 EventLoop 的线程,我理解 IO 事件总是发生在通道分配的 EventLoop 线程上。
我试图通过尽快刷新这些字节来最大程度地减少延迟。 为了更好地了解我可以做些什么来优化这一点,我需要知道这 3 种将数据写入通道的方式之间的区别,以及我可能错过的任何其他方式?
byte[] data = ...
Channel channel = ...
// 1
channel.eventLoop().submit(() -> channel.writeAndFlush(data));
// 2
channel.eventLoop().execute(() -> channel.writeAndFlush(data));
// 3
channel.writeAndFlush(data);
【问题讨论】:
标签: java multithreading netty java.util.concurrent netty-socketio