**1.poll:**int poll(struct pollfd *fds, nfds_t nfds, int timeout);
struct pollfd
{
int fd; —用户关注的文件描述符
short events;—用户关注的事件
short reverts;—由内核修改,表示发生了哪些事件
}
nfds :数组的长度,元素个数,用户关注的文件描述符个数
timeout:超时时间,当timeout为-1时,poll调用将永运阻塞,直到某个事件发生;当timeout为0时,poll调用将立刻返回。
返回值 :-1;出错
0;超时
>0;就绪文件描述符的个数
fd成员指定文件描述符;events成员告诉poll监听fd上的事件;revents成员则由内核修改,以通知应用程序fd实际发生了哪些事件。
表1-1:poll事件类型
2.epoll:int epoll_wait(int epfd, struct epoll_event *events, int maxevents, int timeout);
epoll是linux特有的IO复用函数,下面是epoll特有的函数
1.epoll_create://创建内核事件表
3.epoll_ctl://向内核事件表中添加描述符事件
1.fd:文件描述符
2.op:指定操作类型,操作类型三种:
- EPOLL_CTL_ADD:往事件表中注册fd上的事件
- EPOLL_CTL_MOD:修改fd上的注册事件
- EPOLL_CTL_DEL:删除fd上的注册事件
3.event:参数指定事件,它是epoll_event结构指针类型。epoll_event的定义如下:
- events:成员描述事件类型
- data:用于存储用户数据,其中类型epoll_data_t定义如下:
4.epoll_wait://获取就绪文件描述符
该函数成功返回就绪文件描述符的个数,失败返回-1并设置errno。
maxevents:最多监听多少个事件,它必须大于0
如果该函数检测到事件,就将所有就绪的事件从内核事件表(由epfd参数指定)中复制到它的第二个参数events指向的数组中,这组数组只用于输出epoll_wait检测到的就绪事件。
5.ET与LT
ET:边沿触发模式,是epoll的高效工作模式
LT:电平触发模式,默认的工作模式,在epoll相当于一个效率高的poll,
问题:
1.epoll_create与epoll_ctl的区别
2.ET与LT模式的区别(代码)
https://blog.csdn.net/qq_41026740/article/details/83422775
//没有对就绪的fd进行IO操作,内核会不断的通知。
LT(leveltriggered)是缺省的工作方式,并且同时支持block和no-blocksocket。在这种做法中,内核告诉你一个文件描述符是否就绪了,然后你可以对这个就绪的fd进行IO操作。如果你不作任何操作,内核还是会继续通知你的,所以,这种模式编程出错误可能性要小一点。传统的select/poll都是这种模型的代表。
//没有对就绪的fd进行IO操作,内核不会再进行通知。
ET(edge-triggered)是高速工作方式,只支持no-blocksocket。在这种模式下,当描述符从未就绪变为就绪时,内核通过epoll告诉你。然后它会假设你知道文件描述符已经就绪,并且不会再为那个文件描述符发送更多的就绪通知,直到你做了某些操作导致那个文件描述符不再为就绪状态了(比如,你在发送,接收或者接收请求,或者发送接收的数据少于一定量时导致了一个EWOULDBLOCK错误)。但是请注意,如果一直不对这个fd作IO操作(从而导致它再次变成未就绪),内核不会发送更多的通知(only once),不过在TCP协议中,ET模式的加速效用仍需要更多的benchmark确认(这句话不理解)。
原文链接:https://blog.csdn.net/yusiguyuan/article/details/15027821