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


在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()会当即返回,并收到多少数据返回多少数据。
 
struct timeval结构体在time.h中的定义为: struct timeval { __time_t tv_sec;        /* Seconds. */ __suseconds_t tv_usec;    /* Microseconds. */ }; 其中,tv_sec为Epoch到建立struct timeval时的秒数,tv_usec为微秒数,即秒后面的零头。好比当前我写博文时的tv_sec为1244770435,tv_usec为 442388,即当前时间距Epoch时间1244770435秒,442388微秒。
相关文章
相关标签/搜索