在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; }