
epoll 中 Socket 可读与可写事件的判断
epoll 机制中,可读和可写事件的判断方式存在差异:
可读事件 (EPOLLIN):
可读事件的触发依赖于 Socket 接收缓冲区的状态。当接收缓冲区中存在数据(数据长度大于 0)时,操作系统会自动触发可读事件,告知应用层有数据可读。反之,缓冲区为空时,则不会触发可读事件。
可写事件 (EPOLLOUT):
里面有2个文件夹。其中这个文件名是:finishing,是我项目还没有请求后台的数据的模拟写法。请求后台数据之后,瀑布流的js有一点点变化,放在文件名是:finished。变化在于需要穿参数到后台,和填充的内容都用后台的数据填充。看自己项目需求来。由于chrome模拟器是不允许读取本地文件json的,所以如果你要进行测试,在hbuilder打开项目就可以看到效果啦,或者是火狐浏览器。
与可读事件不同,可写事件并非由操作系统直接监控发送缓冲区状态来触发。而是由应用层程序根据需要手动设置。 操作系统仅在应用层请求注册可写事件后,并在发送缓冲区具备可用空间时,才将该 Socket 的可写事件添加到 epoll 事件集合中。
举例来说,在处理 HTTP 响应后,需要向客户端发送关闭连接的指令。此时,接收缓冲区可能已为空(无数据可读),但需要向发送缓冲区写入数据来关闭连接。因此,程序会主动设置可写事件,以便在发送缓冲区可用时,将关闭连接的指令发送出去。
总结:
- 可读事件: 由操作系统根据接收缓冲区数据量自动触发。
- 可写事件: 由应用层程序手动设置,并由操作系统在发送缓冲区有可用空间时触发。 这使得应用层可以精确控制何时尝试写入数据,避免不必要的等待或错误。









