muduo源码分析2:整体框架

来源:互联网 发布:php foreach用法 编辑:程序博客网 时间:2024/05/24 06:25

muduo简化类图:
这里写图片描述
Channel 是selectable IO channel,负责注册与响应IO 事件,注意它不拥有file
descriptor。它是Acceptor、Connector、EventLoop、TimerQueue、TcpConnection
的成员,生命期由后者控制。
Socket 是一个RAII handle,封装一个file descriptor,并在析构时关闭fd。它是
Acceptor、TcpConnection 的成员,生命期由后者控制。EventLoop、TimerQueue
也拥有fd,但是不封装为Socket class。
SocketsOps 封装各种Sockets 系统调用。
Poller 是PollPoller 和EPollPoller 的基类,采用“电平触发”的语意。它是
EventLoop 的成员,生命期由后者控制。
PollPoller 和EPollPoller 封装poll(2) 和epoll(4) 两种IO multiplexing 后
端。poll 的存在价值是便于调试,因为poll(2) 调用是上下文无关的,用
strace(1) 很容易知道库的行为是否正确。
Connector 用于发起TCP 连接,它是TcpClient 的成员,生命期由后者控制。
Acceptor 用于接受TCP 连接,它是TcpServer 的成员,生命期由后者控制。
TimerQueue 用timerfd 实现定时,这有别于传统的设置poll/epoll_wait 的等
待时长的办法。TimerQueue 用std::map 来管理Timer,常用操作的复杂度是
O(logN),N 为定时器数目。它是EventLoop 的成员,生命期由后者控制。
EventLoopThreadPool 用于创建IO 线程池,用于把TcpConnection 分派到某个
EventLoop 线程上。它是TcpServer 的成员,生命期由后者控制。

0 0