socket通信阻塞模式下,设置发送和接受函数超时

项目中遇到socket通信时接收数据偶尔失败导致阻塞,通过setsockopt()函数设置recv()和send()的超时时间来避免。使用struct timeval结构体指定超时时间,并注意在recv()中使用MSG_WAITALL参数,当对方关闭socket时,recv()会立即返回已接收的数据。
摘要由CSDN通过智能技术生成

今天公司项目上遇到了一个问题,就是用到socket与服务器通信时,接收数据会突然有一次接收不到数据。但是项目代码使用阻塞程序写的,所以程序就一直卡在接收函数不能动。开始为了解决这个问题可以说是费劲周折。先是用了定时器,但是项目代码用的是多进程,要涉及到进程间通信的问题。

后面从网上搜到了下面这一段文字,帮助了我的大忙,真是太感谢了。在阻塞状态下,接收和发送函数同样可以设置接受发送超时时间,而只要是进程不被阻塞,就有办法解决为什么就收不到数据的问题。

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

在send(),recv()过程中有时由于网络状况等原因,收发不能预期进行,而设置收发超时控制: 
在Linux下需要注意的是时间的控制结构是struct timeval而并不是某一整型数,
int nNetTimeout=1000;//1秒, 
//设置发送超时 
setsockopt(socket&#

可以通过设置socket发送超时选项来实现阻塞socket发送超时。在C语言中可以使用setsockopt函数设置socket选项。具体步骤如下: 1. 创建socket并连接服务器。 2. 设置发送超时选项SO_SNDTIMEO,使用setsockopt函数设置。 3. 发送数据,如果发送超时则返回错误码。 示例代码: ``` #include <stdio.h> #include <stdlib.h> #include <string.h> #include <sys/socket.h> #include <netinet/in.h> #include <arpa/inet.h> #include <unistd.h> #include <errno.h> int main(int argc, char *argv[]) { int sockfd; struct sockaddr_in servaddr; char sendline[1024]; if(argc != 2) { printf("usage: %s <IP address>\n", argv[0]); exit(1); } if((sockfd = socket(AF_INET, SOCK_STREAM, 0)) < 0) { printf("socket error: %s\n", strerror(errno)); exit(1); } bzero(&servaddr, sizeof(servaddr)); servaddr.sin_family = AF_INET; servaddr.sin_port = htons(8888); if(inet_pton(AF_INET, argv[1], &servaddr.sin_addr) <= 0) { printf("inet_pton error for %s\n", argv[1]); exit(1); } if(connect(sockfd, (struct sockaddr*)&servaddr, sizeof(servaddr)) < 0) { printf("connect error: %s\n", strerror(errno)); exit(1); } // 设置发送超时选项为5秒 struct timeval tv; tv.tv_sec = 5; tv.tv_usec = 0; if(setsockopt(sockfd, SOL_SOCKET, SO_SNDTIMEO, &tv, sizeof(tv)) < 0) { printf("setsockopt error: %s\n", strerror(errno)); exit(1); } // 发送数据 sprintf(sendline, "hello world"); if(send(sockfd, sendline, strlen(sendline), 0) < 0) { if(errno == EWOULDBLOCK) { printf("send timeout\n"); } else { printf("send error: %s\n", strerror(errno)); } exit(1); } close(sockfd); return 0; } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值