[英]Flush operation for Java non-blocking socket
在普通的阻塞套接字中,我可以使用Socket.getOutputStream()。flush()来部分控制何时发送TCP数据包。 SocketChannel是否有等效的操作?
编辑:我的猜测是,每次我调用SocketChannel.write(ByteBuffer src)时,至少会发送一个单独的数据包,即使缓冲区只有1个字节(假设Nagle已关闭),对吗?
编辑:程序包->数据包,抱歉拼写错误。
我想你可以写一些像
while (buf.hasRemaining()) {
socketChan.write(buf);
}
也许有更好的解决方案。
正如我最近指出的那样,Socket.getOutputStream()。flush()在Sun的JDK 6中没有任何作用。
但是,没有保证write()将发送一个可以发送或多或少的数据包(不是包)。 您所知道的是,它已经传递给操作系统进行处理。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.