选择()不起作用

时间:2016-02-23 13:41:30

标签: c sockets unix time timeout

我需要实现一个接收表达式长度并将从客户端接收它的服务器代码,它应该等待500毫秒,如下所示:

当服务器收到长度消息时,它将等待最多500毫秒的时间来发送该字节数。

该程序由一个简单的UDP服务器 - 客户端程序组成,客户端发送一个表达式,服务器对其进行处理。我正在使用sendto()recvfrom()分别在客户端/服务器之间发送数据。 这段代码应该在unix机器上运行。我看到一个类似的question有同样的问题,它已经解决了,但不适合我。我已经将代码更改为与recvfrom()系统调用更相似,但它仍然无效。有人可以猜到它为什么不起作用吗?

ssize_t timeout_recvfrom(int sock, void *restrict buf, size_t length, int flags,
                         struct sockaddr_in *restrict connection, socklen_t *restrict len, float timeout){
fd_set socks;
    struct timeval t;
    FD_ZERO(&socks);
    FD_SET(sock, &socks);
    t.tv_sec = timeout;
    int aux = select(sock + 1, &socks, NULL, NULL, &t);
    long recvlen = recvfrom(sock, buf, length, 0, (struct sockaddr *) connection, len);
    if (aux && recvlen != -1) {
        return recvlen;
    }
    else {
        printf("select value: %d and recvlen: %lu\n",aux,recvlen);
        perror("cannot select()");
        return 0;
    }
}

服务器以这种方式调用此函数:

//recvlen = recvfrom(fd, buf, sizeof(buf) - 1, 0, NULL, 0);
recvlen = timeout_recvfrom(fd, buf, sizeof(buf) - 1, 0, NULL, 0, 0.5);

评论版本有效,另一个没有,它输出:

select value: 0 and recvlen: 5
cannot select(): Undefined error: 0
Received 0 bytes
Received message: ""

Invalid term: `(null)'

recvlen()应该有5个值,我猜aux不应该是0。

1 个答案:

答案 0 :(得分:2)

您选择的呼叫返回0,表示超时已过期。你没有初始化超时的微秒部分,因为你用0.5作为超时调用函数,秒部分的秒部分被初始化为0(微秒部分可能是垃圾)。 - 艺术