多路io复用 Epoll

比poll功能更完善,没有任何函数的名字叫Epoll,但是有函数叫select和poll

关于Epoll的函数有三个

    1.epoll_create

    2.epoll_ctl

    3.epoll_wait

epoll_create

函数原型:int epoll_create(int size);

返回值:指向epoll实例的文件描述符epfd

Epoll_create创建一个红黑树,一个链表

Epoll_ctl

函数原型:int epoll_ctl(int epfd, int op, int fd, struct epoll_event *event);

参数:

int epfd:epoll_create的返回值

int op:

        EPOLL_CTL_ADD增加一个需要监听的文件描述符

        EPOLL_CTL_DEL删除一个正在舰艇的文件描述符

        EPOLL_CTL_MOD更改一个文件描述符正在舰艇的事件

int fd:当前需要操作的文件描述符的值

struct epoll_event* event:

结构体:

           typedef union epoll_data {

               void        *ptr;

               int          fd;

               uint32_t     u32;

               uint64_t     u64;

           } epoll_data_t;

           struct epoll_event {

               uint32_t     events;      /* Epoll events */

               epoll_data_t data;        /* User data variable */

           };

如果我现在希望让epoll帮我监听5文件描述符的读事件,我们改怎么写代码

int epfd = Epoll_create(64);

event.events = EPOLLIN;

events.data.fd = 5;

Epoll_ctl(epfd,EPOLL_CTL_ADD,5,&evevnt);//在操作这个红黑树,将5这个文件描述符放到红黑树里面去了,就是放内核里面了,所以就没有大量的数据拷贝了,但会消耗大量的内存空间,还会注册一个回调函数call_back(),放在链表里,解决了轮询监听

struct epoll_event events[maxevents];

int ret = Epoll_wait(epfd,events,maxevents,-1);

if(ret > 0)

{

    for(int i=0;i<ret;i++)

    {

        if()

    }

}

epoll_wait

函数原型:

int epoll_wait(int epfd, struct epoll_event *events, int maxevents, int timeout);//专门把双向链表上的元素拷贝到epoll_wait传入的events数组里,就等于把内核空间拷贝到用户空间,所以

参数:

int epfd = Epoll_create(64);

struct epoll_event *events 结构体数组,传出参数

int maxevents events 能装多少个元素

int timeout 超时时间ms

返回值为触发事件文件描述符的个数

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值