例如,我可以在Windows中使用fd_set.fd_array[i]
访问它们。
request_list getIncomingRequests()
{
fd_set master_set_copy = master_set;
request_list requests;
int socket_count = select(0, &master_set_copy, nullptr, nullptr, nullptr);
for (int i = 0; i < socket_count; ++i)
{
#ifdef _WIN32
auto req_fd = master_set_copy.fd_array[i];
#else
auto req_fd = master_set_copy...[i]; // ??
#endif
sockaddr_in req_addr;
getsockname(req_fd, (sockaddr*)&req_addr, &addr_len);
requests.push_back(request(req_fd, this->fd, req_addr));
}
return requests;
}
但是fd_array
在Linux中不存在,因此我需要一个等效的文件。
答案 0 :(得分:5)
fd_set
的POSIX实现不需要结构具有字段fd_array
。 fd_set
应该是不透明的数据结构。
您可以通过遍历所有受支持的描述符(0
至FD_SETSIZE-1
)并调用FD_ISSET()
来检查设置了哪些文件描述符。
注意:
select()
只能监视小于FD_SETSIZE
的文件描述符号;poll(2)
没有此限制。请参阅错误。
答案 1 :(得分:1)
添加一个新变量,也许是max_fd
,该变量跟踪集合中编号最高的文件描述符。然后,您可以执行以下操作:
request_list getIncomingRequests()
{
fd_set master_set_copy = master_set;
request_list requests;
int socket_count = select(max_fd + 1, &master_set_copy, nullptr, nullptr, nullptr);
for (int req_fd = 0; req_fd <= max_fd; ++req_fd)
{
if (!FD_ISSET(req_fd, &master_set_copy))
continue;
sockaddr_in req_addr;
getsockname(req_fd, (sockaddr*)&req_addr, &addr_len);
requests.push_back(request(req_fd, this->fd, req_addr));
}
return requests;
}
但是您最好使用poll
而不是select
。