![](https://img.laitimes.com/img/_0nNw4CM6IyYiwiM6ICdiwiIyVGduV2QvwVe0lmdhJ3ZvwFM38CXlZHbvN3cpR2Lc1TPB10QGtWUCpEMJ9CXsxWam9CXwADNvwVZ6l2c052bm9CXUJDT1wkNhVzLcRnbvZ2LcZXUYpVd1kmYr50MZV3YyI2cKJDT29GRjBjUIF2LcRHelR3LcJzLctmch1mclRXY39zN1QzNxMjM1ETMxEDM2EDMy8CX0Vmbu4GZzNmLn9Gbi1yZtl2Lc9CX6MHc0RHaiojIsJye.jpg)
图中FileDescriptor、socket都不是类
EventLoop:loop --》poller::loop --》pollPoller ::loop 或者epollpoller::poll,循环等待io事件发生,发生后Eventloop得到activeChannels_ 活动通道(保存了发生的事件与回调处理函数),并调用该事件的回调处理函数(活动通道channel中注册的回调处理函数,Eventloop::loop中只能处理短时间回调函数,如果时长时间的应该加入都工作线程池来处理)
EventLoop中绝大数成员方法都要求在本io线程中调用,不支持跨线程调用。
poller是抽象类,pollpoller和epollpoller 是其子类,实现poll(),updateChannel(),和 removeChannel() 三个纯虚函数。
channel类:文件描述符和要关注事件和返回事件、事件发生时的回调函数注册 的封装
eventloop中只有一个 boost::scoped_ptr<Channel> wakeupChannel_ 要管理其生存期
typedef std::vector<Channel*> ChannelList; ChannelList activeChannels_; activeChannels_中的活动channel的生存期 eventloop它不管理
Channel是Acceptor、Connector、TimerQueue、TcpConnection的成员,生命期由后者控制
Acceptor、Connector等调用channel的
void enableReading() { events_ |= kReadEvent;update(); }
void enableWriting() { events_ |= kWriteEvent;update(); }
void disableWriting() { events_ &= ~kWriteEvent;update(); }
void disableAll() { events_ = kNoneEvent;update(); }
void remove( );
来更新,删除channel .
channel::update 和remove --》EventLoop::updateChannel(),和 removeChannel() --》poller::updatchannel和removeChannel --》epollpoller或者pollpoller 的updateChannel和removeChannel
参考:c++教程网
muduo网络库
linux多线程服务器端编程 .陈硕