1.句柄
IO框架库要处理的对象,即 IO事件,信号和定时事件,统一称为事件源。
一个事件源通常和一个句柄绑在一起。句柄的作用是,当内核检测到就绪事件时,它将通过
句柄来通知应用程序这一事件。Linux 下,IO事件对应的句柄就是文件描述符,信号事件对应的
句柄就是信号值。
2.事件多路分发器
事件的到来是随机的,异步的。我们无法预知程序何时收到一个客户连接请求,亦或者收到一个暂停信号。
所以程序需要循环的等待并处理事件,这就是事件循环。在事件循环中,等待事件一般使用IO复用技术来实现。
IO 框架库一般将系统支持的各种IO复用系统调用封装成统一的接口,称为事件多路分发器。事件多路分发器的 demultiplex
方法是等待事件的核心函数,起内部调用的是 select, poll, epoll_wait 等函数.
3.事件处理器/具体事件处理器
事件处理器执行事件对应的业务逻辑。它通常包含一个或者多个 handle_event 回调函数,这些回调函数在事件循环中被执行。
IO框架库提供的事件处理器通常是一个接口,用户需要继承它来实现自己的事件处理器,即具体事件处理器。因此,事件处理器中的
回调函数一般被声明为虚函数,以支持用户的扩展。
4.Reactor
Reactor 是 IO 框架库的核心。它提供的几个主要方法是:
handle_events.该方法执行事件循环。它重复如下过程:等待事件,然后依次处理所有就绪事件对应的事件处理器。
register_handler. 该方法调用事件多路分发器的 register_event 方法来往事件多路分发器中注册一个事件。
remove_handle. 该方法调用事件多路分发器的 remove_event 方法来删除事件多路分发器中的一个事件。
12.1 IO 框架库概述
12.2 Libevent 源码分析