muduo源码分析:reactor模型封装

本文详细分析了muduo库中的reactor模型,重点介绍了EventLoop的loop机制,如何通过poller(如pollPoller和epollPoller)监听并处理IO事件。EventLoop确保在指定的IO线程中执行操作,并且channel类封装了文件描述符、事件关注及回调函数。Acceptor和Connector等通过调用channel的方法来管理读写事件。同时,讨论了channel的生命周期及其与EventLoop和poller之间的交互。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值