Linux高性能服务器编程——ch12笔记

第12章 高性能I/O框架库Libevent

12.1 I/O框架库概述

基于Reactor模式的I/O框架库包含:

1)句柄:与事件源绑定(I/O事件、信号和定时事件)。当内核检测到就绪事件时,通过句柄来通知应用程序这一事件。I/O事件对应的句柄是文件描述符,信号事件对应的句柄就是信号值。

2)事件多路分发器:等待事件使用I/O复用实现, I/O框架库一般将系统支持的各种I/O复用系统调用封装成统一的接口。核心函数:demultiplex。事件循环:循环等待并处理事件。

3)事件处理器和具体事件处理器:事件处理器执行事件对应的业务逻辑。框架库提供的事件处理器通常是一个接口,用户需要继承它来实现自己的事件处理器,即具体事件处理器。因此,事件处理器中的回调函数一般被声明为虚函数。当事件多路分发器检测到有事件发生时,它是通过句柄来通知应用程序的。因此,必须将事件处理器和句柄绑定,才能在事件发生时获取到正确的事件处理器。

4)Reactor:handle_events(事件循环,重复:等待事件,依次处理所有就绪事件对应的事件处理器)、register_handler(调用事件多路分发器的register_events,往分发器中注册事件)、remove_handler(调用事件多路分发器的remove_event,删除分发器中事件)

12.2 Libevent源码分析

相关推荐
愚昧之山绝望之谷开悟之坡7 分钟前
合格境外投资者
笔记
寒秋花开曾相惜2 小时前
(学习笔记)3.8 指针运算(3.8.3 嵌套的数组& 3.8.4 定长数组)
java·开发语言·笔记·学习·算法
_李小白3 小时前
【AI大模型学习笔记之平台篇】第五篇:Trae常用模型介绍与性能对比
人工智能·笔记·学习
承渊政道3 小时前
【优选算法】(实战体会位运算的逻辑思维)
数据结构·c++·笔记·学习·算法·leetcode·visual studio
承渊政道3 小时前
【优选算法】(实战推演模拟算法的蕴含深意)
数据结构·c++·笔记·学习·算法·leetcode·排序算法
左左右右左右摇晃4 小时前
系统性能指标与损耗分析
笔记
悠哉悠哉愿意5 小时前
【单片机复习笔记】第十六届省赛复盘
笔记·单片机·嵌入式硬件
iThinkAi智能体6 小时前
1个运营带4个实习生,周产350篇笔记:小红书图文矩阵真的没那么玄乎
人工智能·经验分享·笔记
Yu_Lijing6 小时前
基于C++的《Head First设计模式》笔记——备忘录模式
c++·笔记·设计模式·备忘录模式
再玩一会儿看代码7 小时前
Java中 next() 和 nextLine() 有什么区别?一篇文章彻底搞懂
java·开发语言·经验分享·笔记·学习