您的位置:首页 > 其它

muduo源码分析2:整体框架

2017-04-11 16:16 232 查看
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 的成员,生命期由后者控制。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: