在C中选择,为什么会失败?

时间:2013-05-21 16:17:58

标签: c linux sockets file-descriptor

我正在使用select(2)函数查看C语言中的代码。在此代码中,当一组两个套接字中的任何一个准备就绪时,select函数应该返回一个不同于0的数字。然而,即使在select之前声明套接字并且当我 netstat --listen 我得到其中一个套接字(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))  { 

1 个答案:

答案 0 :(得分:2)

实际上,select(2)的第一个参数是 the highest-numbered file descriptor in any of the three sets, plus 1 ,而不是FD_SETSIZE,这只是fd_set占用的字节数

然后从select(2)返回零表示超时已到期。检查您是否确实有线上的数据,使用tcpdump(1)wireshark