linux设置send时间,[转]Socket 的send,recv在windows与linux下的超时设置

从昨天到今天一真在搞这个网络断线检测的问题,一直没搞好,网上大多都说用ping

可以搞定,不过我就是搞不定,没办法之下想了个不是办法的办法,在

服务器上开了一个

UDP端口,监听数据,然后回发,不用TCP是因为TCP建立连接太慢了,我发送一个测试数据,数据量小用不着TCP。

这样终端通过去连接服务器的 UDP端口来判断网络状态,听起来不怎么靠谱,不过先用着了。

今天又遇到recvfrom阻塞接收的问题,网络不通就一直等,想改成非阻塞的,也不可靠谱。最后设置了一个超时时间。写这几句话就是想说

setsockopt设置

超时间的问题

setsockopt(uSock,SOL_SOCKET,SO_SNDTIMEO,(char*)&TimeOut,sizeof(TimeOut));

不行,一直是设置失败,后来改成下面这个就行了

struct

timeval tv_out;

tv_out.tv_sec = 10;//等待10秒

tv_out.tv_usec = 0;

setsockopt(sock_fd,SOL_SOCKET,SO_RCVTIMEO,&tv_out,

sizeof(tv_out))

网络上搜到的大都是第一种方法,可能是setsockopt函数已经变了,不适应以前的参数了

2010-08-06 17:43

send,recv在windows与linux下的超时设置linux下:

用socket发送数据前,可以先设置其属性,指定超时时间。超时时间包括接收超时时间和发送超时时间,假设设置接收超时时间为2秒,可以这样:

int time_out = 2000; // 2秒

setsockopt(sockfd, SOL_SOCKET,SO_RCVTIMEO, (char

*)&time_out,sizeof(time_out));

但是在程序中,你可能会发现这样设置之后,还是无效,用接收UDP数据时,recvfrom函数仍然阻塞在那里一动不动,为什么?原因是你没有设置socket为非

阻塞的。在设置超时时间之前,先将socket设置为非阻塞的:

fcntl(sockfd ,F_SETFL, O_NONBLOCK);

widows下:要先设置阻塞,然后再setsockopt

int iMode = 0;//block

ioctlsocket(s, FIONBIO,

(u_long FAR*) &iMode);

DWORD

TimeOut=1000*10;

//设置发送超时10秒

if(::setsockopt(s,SOL_SOCKET,SO_RCVTIMEO,(char

*)&TimeOut,sizeof(TimeOut))==SOCKET_ERROR)

........

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值