epoll学习:epoll_ctl函数详解

一、epoll_ctl函数

1.1、函数定义

int epoll_ctl(int epfd,int op,int fd,struct epoll_event * event);

作用: 向文件描述符epfd引用的epoll实例执行控制操作(op:添加、修改或者删除)。

1.2、参数详解:

1) int epfd: epoll_create()函数返回的epoll实例的句柄。

2) int op: 需要执行的操作,添加,修改,删除。

操作类型描述
EPOLL_CTL_ADD在epoll的监视列表中添加一个文件描述符(即参数fd),指定监视的事件类型(参数event)
EPOLL_CTL_MOD修改监视列表中已经存在的描述符(即参数fd)对应的监视事件类型(参数event)
EPOLL_CTL_DEL将某监视列表中已经存在的描述符(即参数fd)删除,参数event传NULL

3) int fd: 需要添加,修改,删除的socket文件描述符

4) struct epoll_event * event: 需要epoll监视的fd对应的事件类型

1.3、返回值:

成功epoll_ctl()返回0。错误返回-1。错误码error(详见第三节)会被设置。

二、struct epoll_event结构体

2.1、结构体定义

typedef union epoll_data {
      void *ptr;
       int fd;
      uint32_t u32;
      uint64_t u64;
} epoll_data_t;
 
struct epoll_event {
      uint32_t events; /* Epoll 监视的事件类型 */
      epoll_data_t data; /* 用户数据 */
};

3.2、参数解释

1) data: 用户数据
data是一个联合体类型,可以是指针,文件描述符,整形(机器字长)。这个数据传给epoll以后,epoll不会使用,只会在对应的事件触发后原样的返回给用户实际开发中一般都是保存添加的套接字的描述符,用于当epoll事件返回时识别fd。如果有需要传其它值也可以,比如改成一个结构体或者对象的地址(可以避免一次使用套接字查找对象操作)。

2) events: 事件集合
  通过位掩码的方式表示不同的事件,可以同时设置多个,通过“|” 连接,可选项如下。

事件类型描述
EPOLLIN文件描述符是否可读
EPOLLOUT文件描述符是否可写
EPOLLRDHUP对端关闭连接(被动),或者套接字处于半关闭状态(主动),这个事件会被触发。当使用边缘触发模式时,很方便写代码测试连接的对端是否关闭了连接
EPOLLPRI文件描述符是否异常
EPOLLERR文件描述符是否错误。如果文件描述符已经关闭,继续写入也会收到这个事件。这个事件用户不设置也会被上报
EPOLLHUP套接字被挂起,这个事件用户不设置也会被上报
EPOLLET设置epoll的触发模式为边缘触发模式。如果没有设置这个参数,epoll默认情况下是水平触发模式
EPOLLONESHOT设置添加的事件只触发一次,当epoll_wait(2)报告一次事件后,这个文件描述符后续所有的事件都不会再报告。只是禁用,文件描述符还在监视队列中,用户可以通过epoll_ctl()的EPOLL_CTL_MOD重新添加事件

三、错误码解释:

错误码ID解释
EBADFepfd或者fd不是一个有效的文件描述符
EEXIST当参数是EPOLL_CTL_ADD时,当添加到fd已经在epfd中时,重复添加
EINVAL1、当epfd不是一个文件描述符,或者fd是一个epfd,或者op是不支持的参数。2、设置了参数EPOLLEXCLUSIVE,却没有和其它有效的参数一起设置。3、使用参数EPOLL_CTL_MOD 时同时包含了。4、使用参数EPOLL_CTL_MOD 时,当前epfd中的fd之前已经被设置了
ELOOPepoll监视队列是可以添加epoll描述符的,就是支持嵌套。当嵌套关系成环时,或者嵌套深度超过5层时,会报这个错误
ENOENT使用EPOLL_CTL_MOD 和EPOLL_CTL_DEL添加 修改时,修改的套接字却不在epoll的监视队列中
ENOMEM操作所需要的内存不够
ENOSPC当EPOLL_CTL_ADD添加时,已经超过了epoll的规格限制
EPERM添加的fd不支持epoll。比如添加的是普通文件描述符

四、参考资料:

1、epoll 使用详解–epoll_ctl

  • 5
    点赞
  • 33
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这三个函数都是与 Linux 系统中的 epoll I/O 多路复用机制相关的函数。 1. `epoll_create` 函数用于创建一个 epoll 文件描述符,返回值即为该文件描述符。该函数的原型为: ```c int epoll_create(int size); ``` 其中参数 `size` 表示 epoll 实例中能够关注的最大文件描述符数目,一般可以设置为任意大于 0 的数。 2. `epoll_ctl` 函数用于控制 epoll 实例中的文件描述符,可以用于添加、修改和删除文件描述符的关注事件。该函数的原型为: ```c int epoll_ctl(int epfd, int op, int fd, struct epoll_event *event); ``` 其中 `epfd` 参数表示 epoll 文件描述符,`op` 参数表示操作类型,可选的取值有 `EPOLL_CTL_ADD`、`EPOLL_CTL_MOD` 和 `EPOLL_CTL_DEL`,分别表示添加、修改和删除操作。`fd` 参数表示需要被添加、修改或删除的文件描述符,`event` 参数表示需要关注的事件,包括事件类型和事件数据等信息。 3. `epoll_wait` 函数用于等待 epoll 实例中的文件描述符上发生关注的事件,该函数会阻塞进程直到有事件发生。该函数的原型为: ```c int epoll_wait(int epfd, struct epoll_event *events, int maxevents, int timeout); ``` 其中 `epfd` 参数表示 epoll 文件描述符,`events` 参数表示事件数组,用于存储返回的事件信息,`maxevents` 参数表示最大返回的事件数目,`timeout` 参数表示超时时间,单位为毫秒,如果设置为 -1 则表示永久阻塞直到有事件发生。 总的来说,epoll I/O 多路复用机制通过 `epoll_create` 函数创建一个 epoll 实例,并通过 `epoll_ctl` 函数控制实例中的文件描述符。然后通过 `epoll_wait` 函数等待文件描述符上发生关注的事件,从而实现高效的 I/O 多路复用。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值