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多线程服务器端编程 .陈硕
- muduo源码分析:reactor模型封装
- muduo源码分析--Reactor模式在muduo中的使用
- muduo源码分析--详解muduo多线程模型
- muduo源码分析:异常类封装
- muduo源码分析:线程类Thread封装
- muduo源码分析--Reactor模式的在muduo中的使用(二)
- muduo源码分析--多线程模型适用场合
- 【Netty源码分析】Reactor线程模型
- Netty源码分析之Reactor线程模型
- muduo源码分析:互斥锁、条件变量、倒计时封装
- muduo源码分析之使用封装的Buffer读取数据
- muduo reactor
- muduo源码分析---EventLoopThread
- muduo源码分析--TcpServer
- muduo库源码分析
- libevent源码学习-----Reactor模型
- muduo源码分析---EventLoop类
- muduo源码分析--EventLoopThreadPool类
- maven 之nexus
- YTU 2914: xiaoping学构造函数
- idea使用技巧
- spring 整合 redis,以及spring的RedisTemplate如何使用
- 菜鸟在线带你了解2016年值得期待的手机游戏
- muduo源码分析:reactor模型封装
- poj 1364 king (差分约束)
- Activity伪造Dialog的时候不能全屏显示
- 今天是2016年,1月11号
- TDSCDMA SIB content
- MFC 通讯录
- 手机网页Html代码实现(解决显示页面很小的问题)
- mysql游标循环的使用
- 第1章第2节练习题6 反向输出