当前位置: 技术问答>linux和unix
实用了epoll_wait还需要将socket设置为非阻塞吗?
来源: 互联网 发布时间:2017-01-15
本文导语: 今天看了一段公司底层的老代码,socket通讯使用了epoll_wait来监听接收状态,accept时将接收的socket设置为了非阻塞。 我有2个问题: (1)然后后面的recv流程有如下容错代码,是否有点多余? (2)接收有必要使用非阻...
今天看了一段公司底层的老代码,socket通讯使用了epoll_wait来监听接收状态,accept时将接收的socket设置为了非阻塞。
我有2个问题:
(1)然后后面的recv流程有如下容错代码,是否有点多余?
(2)接收有必要使用非阻塞吗?我个人觉得在不考虑多线程的前提下,使用阻塞模式反而对系统性能有好处,避免无必要的空转。
while(true)
{
recved = recv(fd, data, size, 0);
if (0 recved && (EINTR == errno || errno == EAGAIN))
{
continue;
}
return recved;
}
}
我有2个问题:
(1)然后后面的recv流程有如下容错代码,是否有点多余?
(2)接收有必要使用非阻塞吗?我个人觉得在不考虑多线程的前提下,使用阻塞模式反而对系统性能有好处,避免无必要的空转。
while(true)
{
recved = recv(fd, data, size, 0);
if (0 recved && (EINTR == errno || errno == EAGAIN))
{
continue;
}
return recved;
}
}
|
你不需要跟我说这些,你自己去学习一下ET和LT的区别,然后想说什么再来说。
|
recv(fd, data, size, 0);中并不期待收到size个数据吧,因为很多时候,接收方并不知道发过来的数据有多少,
size只是规定此次可以接受的数据大小。
我理解是,非阻塞情况下,如果没有数据, 去读了就会产生EAGAIN。
在ET模式下,如果socket还有数据没读完, 就算新到来了数据, epoll_wait也不会通知。
通常情况下, 到来的数据会大于或者小于size, 除非数据小于size, 否则一次recv并不能读完到来的数据,
因此需要循环调用recv, 一直读到返回值小于size, 或者没有数据(EAGAIN)为止。
size只是规定此次可以接受的数据大小。
我理解是,非阻塞情况下,如果没有数据, 去读了就会产生EAGAIN。
在ET模式下,如果socket还有数据没读完, 就算新到来了数据, epoll_wait也不会通知。
通常情况下, 到来的数据会大于或者小于size, 除非数据小于size, 否则一次recv并不能读完到来的数据,
因此需要循环调用recv, 一直读到返回值小于size, 或者没有数据(EAGAIN)为止。
您可能感兴趣的文章:
本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。
本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。