以下内容来自man epoll页面:
函数do_use_fd()使用新的就绪文件描述符,直到读(2)或写(2)返回EAGAIN为止。
ET触发的代码示例:
for(;;) {
nfds = epoll_wait(kdpfd, events, maxevents, -1);
for(n = 0; n < nfds; ++n) {
if(events[n].data.fd == listener) {
client = accept(listener, (struct sockaddr *) &local,
&addrlen);
if(client < 0){
perror("accept");
continue;
}
setnonblocking(client);
ev.events = EPOLLIN | EPOLLET;
ev.events = EPOLLIN | EPOLLET;
ev.data.fd = client;
if (epoll_ctl(kdpfd, EPOLL_CTL_ADD, client, &ev) < 0) {
fprintf(stderr, "epoll set insertion error: fd=%d\n",
client);
return -1;
}
}
else
do_use_fd(events[n].data.fd);
}
}所以对于read/write操作,我们应该通过循环来实现,直到接收到EAGAIN;但是为什么accept不是这样的呢?
当有多个等待接受的客户端套接字时,上面的代码将丢失一些请求,因为它只接受1客户端套接字,所以我们也应该将它封装在一个循环中,直到EAGAIN收到为止。
或者也许我遗漏了什么?
发布于 2011-06-19 09:50:05
查看侦听器套接字是如何添加到epollfd的
ev.events = EPOLLIN; // this is the crucial bit
ev.data.fd = listen_sock;它不是加在边缘触发的,而是加在水平触发的。所以不需要一个循环,直到EAGAIN对那个循环。
https://stackoverflow.com/questions/6401642
复制相似问题