我正在使用选择(2)函数检查C中的代码。在这段代码中,select函数应该返回一个与0不同的数字,当两个套接字中的任意一个准备就绪时。然而,即使套接字是在select之前声明的,并且当我在netstat --听我的时候,我得到其中一个套接字(cmd_socket)正在监听它指定的端口,它仍然找不到任何文件描述符。我尝试过强制执行不同的超时,我认为FD_SETSIZE是可以的,因为这段代码以前可以在另一台机器上工作。有什么问题吗?这是代码:
// Program sockets intialization
int cmd_sock = create_and_bind_socket(cmd_port_property(0,GET) ,&src_addr);
mc_sock = create_and_bind_socket(mcast_port_property(0,GET), &mc_addr);
join_multicast_group(mc_sock,mc_addr_str, &mc_req);
int recv_len = 0;
int childs = 0;
struct timeval tv;
struct timeval *ptv = &tv;
if (!timeout) {
ptv = NULL;
} else {
ptv->tv_sec = timeout;
ptv->tv_usec = 0;
}
fd_set readfds, safe;
fdmax = mc_sock;
// Add multicast and unicast sockets to set
FD_ZERO(&readfds);
FD_SET(cmd_sock, &readfds);
FD_SET(mc_sock, &readfds);
safe = readfds;
// Wait until some socket on the set is ready to be read
while(select (FD_SETSIZE,&readfds,NULL,NULL,ptv)) { 发布于 2013-05-21 16:25:07
实际上,the highest-numbered file descriptor in any of the three sets, plus 1,是select(2)的第一个参数,而不是FD_SETSIZE,它只是fd_set接收的字节数。
那么,从select(2)返回的零意味着超时过期。检查你是否真的有数据连线,使用tcpdump(1)或wireshark。
https://stackoverflow.com/questions/16674764
复制相似问题