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

相关推荐
可乐^奶茶2 小时前
2026《数据结构》考研复习笔记二(C++面向对象)
数据结构·c++·笔记
OSwich3 小时前
【虚幻C++笔记】接口
c++·笔记·虚幻
zyq~7 小时前
【论文阅读笔记】模型的相似性
论文阅读·笔记
chxin140168 小时前
PyTorch - Tensor 学习笔记
pytorch·笔记
christine-rr9 小时前
【25软考网工笔记】第二章 数据通信基础(2) 信道延迟计算
网络·笔记·网络工程师·软考
踢足球的程序员·9 小时前
OpenGL学习笔记(几何着色器、实例化、抗锯齿)
笔记·学习·图形渲染
天下琴川11 小时前
Dify智能体平台源码二次开发笔记(6) - 优化知识库pdf文档的识别
人工智能·笔记·pdf
jackson凌11 小时前
【Java学习笔记】运算符
java·笔记·学习
Always_away12 小时前
数据库系统概论|第三章:关系数据库标准语言SQL—课程笔记4
数据库·笔记·sql·学习
嵌入式小小怪下士12 小时前
lx2160 LSDK21.08 firmware 笔记 - 0.基于fip.bin 编译流程展开的 makefile 分析
笔记·lsdk21.08·lx2160/lx2080