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指纹浏览器性能瓶颈分析与优化技巧
经验分享·笔记
雷工笔记3 小时前
随笔|走!跳楼去!
笔记
就叫飞六吧4 小时前
国产数据库gbase8s安装-网盘
笔记
网络工程小王4 小时前
【大数据技术详解】——Kibana(学习笔记)
大数据·笔记·学习
努力的lpp4 小时前
2024小迪安全课程第四节复习笔记
笔记·安全
雷工笔记6 小时前
AI使用|通过AI学习物料分类编码表
笔记·学习
Shea的笔记本6 小时前
MindSpore实战笔记:WaveNet音乐生成复现全记录
笔记
koo3647 小时前
pytorch深度学习笔记23
pytorch·笔记·深度学习
FakeOccupational7 小时前
【电路笔记 STM32】Cortex-M7 内核上的数据缓存结构图 + MPU内存保护单元 + Cache基本操作 + Cache&DMA 时序图
笔记·stm32·缓存