您的位置:首页 > Web前端 > React

muduo源码分析:reactor模型封装

2016-01-11 16:12 661 查看


图中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多线程服务器端编程 .陈硕
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: