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

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 源码分析

 

 

 

 

 

 

 

  • 0
    点赞
  • 0
    收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值