用setsockopt()来控制recv()与send()的超时

转载 2013年12月05日 14:07:18
在send(),recv()过程中有时由于网络状况等原因,收发不能预期进行,而设置收发超时控制:
在Linux下需要注意的是时间的控制结构是struct timeval而并不是某一整型数,以下是来自于网上一篇文章中的摘录,它是这样写的:
int nNetTimeout=1000;//1秒,
//设置发送超时
setsockopt(socket,SOL_SOCKET,SO_SNDTIMEO,(char *)&nNetTimeout,sizeof(int));
//设置接收超时
setsockopt(socket,SOL_SOCKET,SO_RCVTIMEO,(char *)&nNetTimeout,sizeof(int));
这样做在Linux环境下是不会产生效果的须如下定义:struct timeval timeout = {3,0}; 
 
//设置发送超时
setsockopt(socket,SOL_SOCKET,SO_SNDTIMEO,(char *)&timeout,sizeof(struct timeval));
//设置接收超时
setsockopt(socket,SOL_SOCKET,SO_RCVTIMEO,(char *)&timeout,sizeof(struct timeval));
有两点注意就是
1)recv ()的第四个参数需为MSG_WAITALL,在阻塞模式下不等到指定数目的数据不会返回,除非超时时间到。还要注意的是只要设置了接收超时,在没有MSG_WAITALL时也是有效的。说到底超时就是不让你的程序老在那儿等,到一定时间进行一次返回而已。
2)即使等待超时时间值未到,但对方已经关闭了socket, 则此时recv()会立即返回,并收到多少数据返回多少数据。

相关文章推荐

linux socket中的地址转换、返回值和setsockopt()来控制recv()与send()的超时

地址转换时的htonl和inet_pton 参数是32bit的二进制数值,在转换地址时就是32位的主机字节序ip地址(经常用点分十进制) 用法:servaddr.sin_addr.s_addr=...

用setsockopt()来控制recv()与send()的超时

在send(),recv()过程中有时由于网络状况等原因,收发不能预期进行,而设置收发超时控制: 在Linux下需要注意的是时间的控制结构是struct timeval而并不是某一整型数,以下是来自...

关于socket阻塞与非阻塞情况下的recv、send、read、write返回值及用setsockopt()来控制recv()与send()的超时

地址转换时的htonl和inet_pton  参数是32bit的二进制数值,在转换地址时就是32位的主机字节序ip地址(经常用点分十进制)  用法:servaddr.sin_addr.s_ad...

关于socket阻塞与非阻塞情况下的recv、send、read、write返回值及用setsockopt()来控制recv()与send()的超时

地址转换时的htonl和inet_pton  参数是32bit的二进制数值,在转换地址时就是32位的主机字节序ip地址(经常用点分十进制)  用法:servaddr.sin_addr.s_ad...

send-recv-init

网络基础 send/recv

网络基础_send/recv 一.  阻塞和非阻塞         阻塞函数在完成其指定任务以前不允许程序调用另一个函数。当服务器运行到accept语句时,而没有客户端连接服务请求到来...

send函数 和recv函数

关于SOCKET中send和recv函数工作原理总结

send函数工作原理:      send函数只负责将数据提交给协议层。 当调用该函数时,send先比较待发送数据的长度len和套接字s的发送缓冲区的长度,如果len大于s的发送缓冲区的长度,该函数返...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)