关于linux epoll有个问题想请教下各位
我是看的这篇博客https://my.oschina.net/editorial-story/blog/3052308?p=4,里面有部分说到
当程序执行到 epoll_wait 时,如果被监听的socket没有数据返回时,会阻塞,但是问题来了,如果
同一时刻有多个socket有数据返回,那么是不是一个一个的处理,如果是这样,那根本就没做到并行
处理,而且看这部分代码是在单线程处理的;还是说有数据返回时根本不需要做并行处理了,因为耗时
的操作主要是在网络I/O,有数据返回时后续的处理都是很快速的了,不知道我这理解对不对。
如果有实现并行处理的话,它又是怎么处理的呢?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(3)
感谢回答,数据返回是socket缓冲区还没有数据的意思
第一,“数据返回”是个什么概念, 对于通信来说,读和写就完了
第二, epoll_wait单线程处理就行了,至于读数据,没人规定你必须单线程,而且读数据操作通常还说还是比较快的。
第三, 人家只是展示个demo
呃,没人吗.....................