SO_RCVTIMEO 根本没有在我的输出函数中创建超时条件。我正在使用 ARQ 滑动窗口协议设计文件传输服务。为了使事情井井有条,我从基本的停止等待开始。
这是我对 timeval 的初始化
struct timeval tv;
tv.tv_sec = 0;
tv.tv_usec = 100000;
这是我在准备 recvfrom 超时时使用该结构和套接字
if(setsockopt(sock, SOL_SOCKET, SO_RCVTIMEO, &tv, sizeof(tv))<0)
{
fprintf(stderr, "Error in socket option for Timeout mechanism: %s",strerror(errno));
close(sock);
exit(EXIT_FAILURE);
}
if (-1 == bind(sock,(struct sockaddr *)&sa, sizeof(sa)))
{
perror("error bind failed");
close(sock);
exit(EXIT_FAILURE);
}
这是应该超时的代码主体:
for(;;)
{
...
while((read_bytes=fread((char*)&(packet.body),sizeof(char),CHUNKSIZE,out_file))
{
...
while(1)
{
bytes_sent = sendto(sock, (struct sanpacket*)&packet, sizeof(struct sanpacket), 0,(struct sockaddr*)&sa, sizeof sa);
if (bytes_sent < 0)
{
fprintf(stderr, "%s\n", strerror(errno));
exit(EXIT_FAILURE);
}
printf("Waiting for ACK packet\n");
recsize = recvfrom(sock, (struct sanpacket*)&packet, sizeof(struct sanpacket), 0, (struct sockaddr*)&sa, &fromlen);
if(errno == EAGAIN)
{
printf("Timed out; resending packet with sequence number %d", packet.sequence_num);
continue;
}
if (recsize < 0)
{
fprintf(stderr, "%s\n", strerror(errno));
exit(EXIT_FAILURE);
}
}
问题:超时没有触发,但是 setsockopt 也没有返回任何错误。我无法知道我做错了什么。
如果我还能做些什么来澄清我的问题或环境,请告诉我。如果您对调试有任何建议,我将不胜感激。