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 的成员,生命期由后者控制。
muduo源码分析2:整体框架
最新推荐文章于 2025-03-31 22:18:44 发布