epoll接口
epoll_create
创建一个epoll模型
- 自从linux2.6.8之后,size参数是被忽略的
- 返回值是一个文件描述符
- 用完之后, 必须调用close()关闭
epoll_ctl
epoll_ctl用于添加、修改或删除关注的文件描述符,并设置感兴趣的事件类型(如读事件、写事件等)。epoll_ctl事件注册函数,它不同于select()是在监听事件时告诉内核要监听什么类型的事件, 而是在这里先注册要监听的事件类型.
参数:
- 第一个参数是epoll_create()的返回值(epoll模型).
- 第二个参数表示动作,用三个宏来表示.
- 第三个参数是需要监听的fd.
- 第四个参数是告诉内核需要监听什么事件
第二个参数的取值:
- EPOLL_CTL_ADD :添加新的fd到epfd中
- EPOLL_CTL_MOD :修改已经注册的fd的监听事件
- EPOLL_CTL_DEL :从epfd中删除一个fd
struct epoll_event结构如下:
events可以是以下几个宏的集合:本质也是位图的形式
- EPOLLIN : 表示对应的文件描述符可以读 (包括对端SOCKET正常关闭);
- EPOLLOUT : 表示对应的文件描述符可以写;
- EPOLLPRI : 表示对应的文件描述符有紧急的数据可读 (这里应该表示有带外数据到来);
- EPOLLERR : 表示对应的文件描述符发生错误;
- EPOLLHUP : 表示对应的文件描述符被挂断;
- EPOLLET : 将EPOLL设为边缘触发(Edge Triggered)模式, 这是相对于水平触发(Level Triggered)来说的.
- EPOLLONESHOT:只监听一次事件, 当监听完这次事件之后, 如果还需要继续监听这个socket的话, 需要再次把这个socket加入到EPOLL队列里.
epoll_wait
等待事件的发生,并返回准备好的文件描述符集合
- 参数events是分配好的epoll_event结构体数组.
- epoll将会把发生的事件赋值到events数组中 (events不可以是空指针,内核只负责把数据复制到这个events数组中,不会去帮助我们在用户态中分配内存).
- maxevents告之内核这个events有多大,这个 maxevents的值不能大于创建epoll_create()时的size.
- 参数timeout是超时时间 (毫秒,0会立即返回,-1是永久阻塞).
- 如果函数调用成功,返回对应I/O上已准备好的文件描述符数目,如返回0表示已超时, 返回小于0表示函数失败.
epoll工作原理
epoll的实现机制是通过内核与用户空间共享一个事件表。这个事件表中存放着所有需要监控的文件描述