关于AIO异步非阻塞,有如下代码
while(buf.hasRemaining()) {//因为write不能保证有多少数据真实被写入,因此需要循环写入直到没有更多数据。
channel.write(buf);//2.将数据从内核缓冲(ByteBuffer)区写到到io(channel)
}
对于“因为write不能保证有多少数据真实被写入,因此需要循环写入直到没有更多数据。”,这个应该如何理解?为何异步非阻塞时,write不能保证有多少数据写入?
关于AIO异步非阻塞,有如下代码
while(buf.hasRemaining()) {//因为write不能保证有多少数据真实被写入,因此需要循环写入直到没有更多数据。
channel.write(buf);//2.将数据从内核缓冲(ByteBuffer)区写到到io(channel)
}
对于“因为write不能保证有多少数据真实被写入,因此需要循环写入直到没有更多数据。”,这个应该如何理解?为何异步非阻塞时,write不能保证有多少数据写入?
基于Monster 组和GPT的调写:
在异步非阻塞IO中,当应用程序调用write函数将数据写入内核缓冲区时,内核会尝试将缓冲区中的数据尽可能地写入到套接字的发送缓冲区中,但并不保证一定写入成功,因为套接字的发送缓冲区有可能已经满了,此时写操作会返回一个EAGAIN或EWOULDBLOCK错误码,表示发送缓冲区已满,需要等待一段时间后再尝试写入。
这就是为什么异步非阻塞IO中write函数不能保证有多少数据写入的原因。因此,如果应用程序需要发送大量的数据,就需要使用循环写入的方式,反复调用write函数,直到所有数据都成功写入为止。
另外,需要注意的是,异步非阻塞IO中的写入操作并不会真正地等待数据发送完成后再返回,而是会立即返回,如果数据无法写入,内核会将其放入发送缓冲区,并通过事件通知机制告诉应用程序何时可以继续写入数据。因此,应用程序需要在后续的写入操作中再次检查缓冲区是否已满,以保证数据能够尽可能地被发送出去。