连续看了两天的muduo库的net部分,看得我头昏脑胀。。。不过总算把net部分的消息循环机制大致看懂了,不像一开始那么懵逼了。。。
思路:
简单说来就是将poll/epoll封装成监听类,然后事件分发类从监听类哪里拿到要处理的事件,然后执行事件对应的回调函数。
类:
Channel:
- 更新Poller对象的监听列表
- 设置回调函数
- 执行回调函数(即处理消息用的函数)
Poller:
- 执行轮询,获取监听到的事件
- 返回实际坚挺到的事件列表
EventLoop
- 使Poller执行一次轮询监听事件
- 获取Poller监听到的事件列表
- 通过Channel对象执行事件列表中事件对应的回调函数
TcpServer:
- 实例化一个Acceptor对象,实例化的时候传入回调函数的函数指针
- 设置回调函数
- 将Acceptor对象的listen函数传给EventLoop执行,从而更新EventLoop的事件监听列表
Acceptor:
- 处理新链接消息
各给类之间的关系:
未完待续。。。写累了。。。