muduo源码分析:reactor模型封装

来源:互联网 发布:excle筛选重复数据 编辑:程序博客网 时间:2024/05/23 00:05

图中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多线程服务器端编程 .陈硕


0 0
原创粉丝点击