600字范文,内容丰富有趣,生活中的好帮手!
600字范文 > 12.Linux 高性能服务器编程 --- 高性能 IO 框架库 Libevent

12.Linux 高性能服务器编程 --- 高性能 IO 框架库 Libevent

时间:2019-09-17 03:37:29

相关推荐

12.Linux 高性能服务器编程 --- 高性能 IO 框架库 Libevent

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

12.1 IO 框架库概述

12.2 Libevent 源码分析

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。