Libevent的使用及reactor模型

Libevent 是一个用C语言编写的、轻量级的开源高性能事件通知库,主要有以下几个亮点:事件驱动( event-driven),高性能;轻量级,专注于网络,不如 ACE 那么臃肿庞大;源代码相当精炼、易读;跨平台,支持 Windows、 Linux、 *BSD 和 Mac Os;支持多种 I/O 多路复用技术, epoll、 poll、 dev/poll、 select 和 kqueue 等;支持 I/O,定时器和信号等事件;注册事件优先级。

libevent的流程可以分为三步:定义框架,注册事件,启动事件循环(epoll检测事件是否发生,发生的时候,通知子线程调用回调函数//此过程会阻塞)下图为编写的框架

cpp 复制代码
  // 创建框架  
  struct event_base* base = NULL;
    base = event_base_new();

  
// 添加事件
    struct event* ev = NULL;
    ev = event_new(base, fd, EV_READ | EV_PERSIST, read_cb, NULL);

    event_add(ev, NULL);

    // 事件循环
    event_base_dispatch(base);

    // 释放资源
    event_free(ev);
    event_base_free(base);
    close(fd);
    
    return 0;
}

Reactor:事件源(描述符)、Reactor 框架、多路复用机制和事件处理程序

事件源可以理解为我们的文件描述符,多路复用机制是我们的IO模型(select,poll,epoll),事件处理程序理解为回调函数。

相关推荐
wang09075 天前
什么是reactor以及其三种版本
reactor·reactor工作模式·reactor三种版本
玩AI的小胡子1 个月前
AI人像换脸!Reactor插件本地部署方法(含报错解决及整合包)
ai作画·stable diffusion·aigc·reactor·ai写真
一眼万里*e2 个月前
libevent入门篇
c++·libevent
Philosophy3 个月前
libevent之evbuffer
libevent
重庆大傑3 个月前
Reactor模型:网络线程模型演进
java·服务器·网络·reactor·nio
重庆大傑4 个月前
Socket 原理和思考
java·reactor·socket·nio
炫酷的伊莉娜4 个月前
【Linux 网络】高级 IO -- 详解
linux·网络·select·reactor·高级io·epoll·poll
东皋长歌5 个月前
响应式编程Spring Reactor探索
java·开发语言·spring·reactor·响应式编程
haidi85 个月前
一篇了解reactor框架特性
java·reactor·reactor代码调试
@背包5 个月前
高级IO|从封装epoll服务器到实现Reactor服务器|Part1
服务器·reactor·epoll·多路转接服务器