框架设计思路
- libevent使用统一事件源将所有问题都转化为event,比如将套接字/信号/描述符都在内部转化为event,由相应的io多路复用函数进行监控。
- 为了提供对超时event的支持,libevent将所有的超时时间都转化为绝对时间,这就将杂乱无章的超时event有序管理起来,同时采用最小堆存储那些具有超时时间的event,这样当堆顶event没有超时,那么堆中所有event都不会超时。
- libevent采用Reactor反应器模式来处理所有的event,内部使用io多路复用进行监控,又因为需要由libevent主动调用用户的回调函数,所以libevent内部大量使用函数指针保存和调用用户提供的回调函数,其实就是利用函数指针实现多态
- 是出现一个激活event就调用对应回调函数,还是先将所有激活event存在一起,统一调用。显然更好的是后者,因为可以对激活event进行管理,包括event优先级等
- 至此就可以在event_base_new,event_new,event_add基础上进行扩展,包括封装socket api,设计tcp缓冲区等
源码阅读心得
其实主要还是细节问题,抛开各种错误处理不管,libevent可以学习的内容非常多
对io多路复用函数的封装,实现跨平台
如何对各种io复用函数的接口实现统一,是对其封装首先要考虑的问题。为了统一,就需要设计一个统一的接口,在对io复用进行封装时都根据这个统一接口进行。
libevent便是设计了统一的接口struct,内部包含io复用名字字符串,io函数的各种接口的函数指针。这样在封装时只需要每一个io复用函数都按照这种格式提供响应的字符串和函数指针,在base的调用中就不需要关系具体是哪个io函数了
此外对于每一个io复用函数使用的数据,比说说poll的pollfd,epoll的epoll_event,select的fd_set也需要统一的管理,但这个管理就不需要那么中规中矩了,因为这些数据是在