在send(),recv()过程中有时由于网络状况等原因,收发不能预期进行,而设置收发超时控制:
以下是来自于网上一篇文章中的摘录,它是这样写的:
int nNetTimeout=1000;//1秒, //设置发送超时 setsockopt(socket,SOL_SOCKET,SO_SNDTIMEO,(char *)&nNetTimeout,sizeof(int)); //设置接收超时 setsockopt(socket,SOL_SOCKET,SO_RCVTIMEO,(char *)&nNetTimeout,sizeof(int));
有两点注意就是:
1)recv ()的第四个参数需为MSG_WAITALL(设置MSG_DONTWAIT可以不用阻塞在建立连接后在等等接收数据),在阻塞模式下不等到指定数目的数据不会返回,除非超时时间到。还要注意的是只要设置了接收超时,在没有MSG_WAITALL时也是有效的。说到底超时就是不让你的程序老在那儿等,到一定时间进行一次返回而已。
2)即使等待超时时间值未到,但对方已经关闭了socket, 则此时recv()会立即返回,并收到多少数据返回多少数据。
int rst; int nNetTimeout = nTimeOut;//1秒, SOCKET sockClient = socket(AF_INET, SOCK_STREAM, 0); SOCKADDR_IN addrSrv; addrSrv.sin_addr.S_un.S_addr = htonl(wIpAddr); addrSrv.sin_family = AF_INET; addrSrv.sin_port =htons(nPort); setsockopt(sockClient, SOL_SOCKET, SO_SNDTIMEO, (char *)&nNetTimeout, sizeof(int)); rst = connect(sockClient, (SOCKADDR*)&addrSrv, sizeof(SOCKADDR)); if (rst != 0) { return 0; } setsockopt(sockClient, SOL_SOCKET, SO_SNDTIMEO, (char *)&nNetTimeout, sizeof(int)); send(sockClient, "1", 3, 0);//最后一位 为0 是默认值 char recvbuf[4]; memset(recvbuf, 0, 4); setsockopt(sockClient, SOL_SOCKET, SO_RCVTIMEO, (char *)&nNetTimeout, sizeof(int)); recv(sockClient, recvbuf, 100, 0); closesocket(sockClient); if (recvbuf[0] == 'C' && recvbuf[1] == 'D') { return 1; } else { return 0; }