我必须同时处理大约 1000 个描述符poll
(我不能使用epoll
它,因为它是特定于 Linux 的)并且我必须能够动态添加/删除它们(处理新连接并删除关闭)。
这意味着我应该在每次迭代时重新组合描述符数组。
从技术角度来看,这是相当明显的,但有人知道这样做的好方法吗?
我会将已死的描述符保留在数组中,并偶尔清除一次。我还会维护每个描述符的位置,以便于删除,但这可以进一步优化。诀窍是在数组中保留无效的描述符,而不是每次都重新排列数组。
例如:
struct pollfd pfds[MY_MAX_FDS];
int nfds = 0;
enum { INVALID_FD = -1 };
....
typedef std::map<int,int> desc_to_index_t;
desc_to_index_t d2i;
....
// add descriptor
if (nfds == MY_MAX_FDS){
// purge old fds
// go through pfds and remove everything that has invalid fd
// pfds should point to a condensed array of valid objects and nfds should be updated as well, as long as d2i.
}
pfds[nfds] = { desc, events, revents};
d2i.insert(std::make_pair(desc,nfds));
++nfds;
....
// remove descriptor
desc_to_index_t::iterator it = d2i.find(desc);
assert(it != d2i.end());
pfds[it->second] = { INVALID_FD, 0, 0 };
d2i.erase(it);
这样一来,您只需在超过某个阈值时进行清除,而无需每次都构建数组。