在 epoll 上,epoll_data 结构很重要
typedef union epoll_data {
void *ptr;
int fd;
__uint32_t u32;
__uint64_t u64;
} epoll_data_t;
如果对于某些事件,我需要将它与一些附加信息相关联,对于 epoll_data,我需要构造一个结构并使用ptr
指向该结构。在结构里面我放了一个fd
元素,比如
typedef {
int fd;
char* info;
} compound;
但是当我想检查活动事件时,我必须执行以下操作:
for( ; ; )
{
nfds = epoll_wait(epfd,events,20,500);
for(i=0;i<nfds;++i)
{
if(events[i].data.fd==listenfd) {
...
}
else if( ((compound*)events[i].events.ptr)->fd ....){
...
}
}
检查不一致,有时我需要检查events[i].data.fd
,有时我需要检查events[i].data.ptr->fd
。如果我把所有事件都放在一致,即让它们都有一个void ptr,对于一些socket来说,这是一种浪费,因为它们与附加信息无关。
所以我认为 epoll_data 应该有一个独立的int fd
元素,因为fd
通常非常重要。
您对此有何看法?谢谢!