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

相关推荐
lingggggaaaa8 小时前
小迪安全v2023学习笔记(九十七天)—— 云原生篇&Kubernetes&K8s安全&API&Kubelet未授权访问&容器执行
java·笔记·学习·安全·网络安全·云原生·kubernetes
十安_数学好题速析9 小时前
系数调整:四项平方和的最小值攻略
笔记·学习·高考
RickyWasYoung10 小时前
【笔记】非线性状态空间方程线性化时为什么要以平衡点为基准?
笔记
进击的圆儿10 小时前
【学习笔记02】C++面向对象编程核心技术详解
c++·笔记·学习
报错小能手12 小时前
linux学习笔记(16)进程间通信——管道
linux·笔记·学习
灰太狼大王灬12 小时前
Go 项目从开发到部署笔记
开发语言·笔记·golang
聪明的笨猪猪13 小时前
Java “线程池(1)”面试清单(含超通俗生活案例与深度理解)
java·经验分享·笔记·面试
kfepiza13 小时前
`modprobe`命令 与 `KVM`模块 笔记251006
linux·笔记
小秋学嵌入式-不读研版14 小时前
C56-字符串拷贝函数strcpy与strnpy
c语言·开发语言·笔记
晨非辰17 小时前
《剑指Offer:单链表操作入门——从“头删”开始破解面试》
c语言·开发语言·数据结构·c++·笔记·算法·面试