摘要: 前言 : 简单介绍 3 种多线程的模式。 1 暴力抢占 2 纯粹的消息通知机制 3 消息通知加同步层 4 例子 memcached 。memcached 中的网络部分就是基于 Libevent 完成的。其中的多线程模型就是 消息通知 加 同步层机制。 阅读全文
posted @ 2019-05-03 21:09 三二二, 阅读(314) 评论(0) 推荐(0) 编辑
摘要: 前言 : 为了支持定时器, Libevent 必须和系统时间打交道。主要涉及到时间的加减辅助函数、事件缓存、时间校正和定时器堆的时间值调整等。 1 初始化检测 Libevent 在初始化时会检测系统时间的类型,通过调用函数 detect_monotonic() 完成,它通过调用 clock_gett 阅读全文
posted @ 2019-05-03 21:02 三二二, 阅读(368) 评论(0) 推荐(0) 编辑
摘要: 前言 : Libevent 的核心是事件驱动、同步非阻塞,为了达到这一目标,必须使用系统提供的 I/O 多路复用技术。而这些在不同的平台上却各有不同。 1 统一的关键 Libevent 支持多种 I/O 多路复用技术的关键就在于结构体 eventop。它的成员是一系列的函数指针。 struct ev 阅读全文
posted @ 2019-05-03 20:08 三二二, 阅读(245) 评论(0) 推荐(0) 编辑
摘要: 前言 : 与 Signal 相比,Timer 事件的集成会直观和简单很多 1. 集成到事件主循环 因为系统的 I/O 机制都允许程序制定一个最大的等待时间 timeout。就可以根据 Timer 事件的最小超时时间来设置系统 I/O 的 timeout时间。 2 代码解析 if(!base -> e 阅读全文
posted @ 2019-05-03 19:33 三二二, 阅读(186) 评论(0) 推荐(0) 编辑