muduo源码分析--事件回调层次是怎么传递的Tcpserver Channel TcpConnection
muduo库中的源码并不是很多,但是回调的处理非常巧妙,这里从事件激活(某个套接字上可读/可写)以后这个层次看回调怎么被调用的。
首先从最大的EventLoop说起:
首先从最大的EventLoop说起:
EventLoop中拥有事件链表(每一个元素都是Channel),在loop函数中调用epoll_wait系统调用的时候,将EpollPollr中EventList,将这个链表中激活事件添加到EventLoop中的activeChannel中,
所以暂时不管怎么弄EventLoop中的loop()函数已经将所有祖册到这个EventLoop上的被激活fd添加到了其私有变量activeChannel中了(助于怎么添加稍后再议),得到激活链表,对每个Channel调用其handleEvent,这样就结束了这次poll的循环。
接下来议Channel中的handleEvent函数
Channel:
Channel并不拥有fd,在这里有三个回调函数,writeCallback_ readCallback_ closeCallback_
在handleEvent函数中,根据事件类型执行相应的回调,就是上面的三个回调函数,那么这三个回调函数怎么来的呢?肯定是谁拥有Channel谁就会Channel中的这个三个回调赋值。用内有channel的类有Acceptor Connector EventLoop TcpConnection 下面分析用户Channel这个类的四个类是怎么处理这个事情的
其实在Channel中还有将fd添加到EventLoop需要监听的EventList链表中的操作
TcpConnection:
在这个类中是有socketfd的,同时这里有handRead() handleWrite() handleClose()函数
在TcpConnection的初始化中,将上述三个函数赋值给Channel中的writeCallback_ readCallback_ closeCallback_ 。
而且在TcpConnection中这三个函数都是有实现的。在handleRead()函数中,使用了messageCallback_ handlWrite函数中使用了writeCompleteCallback_ handleClose()函数中使用了connectionCallback函数
那么这几个函数是说出入呢?肯定是谁拥有TcpConnection谁就注册这个函数,或者用户自己写自己注册。
管理TcpConnection的有TcpServer和TcpClient
其实在TcpServer中,是用户的函数注册到了
TcpServer类中的相应三个函数,然后再复制给TcpConnection的
这样就明白了从epoll_wait返回到迪欧用自己的用户空间的函数是怎么个流程了,也明白事件被触发后的操作
只知道事件发生时怎么处理,但是这里没有讲述事件是怎么被关注的(下面一篇文章介绍这个内容)
相关推荐
linux下muduo-0.9.1-beta.gz安装包,linux下学习muduo安装使用,ubuntu
muduo的Mutex-thread测试
使用muduo最新版编译后的文件以及头文件,可以直接放入项目中使用。注:编译之后,会在用户目录下生成一个build文件夹,该文件夹下有release-install-cpp11文件夹,里面有两个文件夹分别是include和lib,这是编译后...
网络服务器要处理的对象无外乎,监听者TcpServer,连接接收者Acceptor,连接者TcpConnection等等主体对象。要处理的事件有监听者可写,连接者读写等主体事件。宏观上面,所有的连接可以看作成一个通道Channel,通道...
个人在阅读muduo源码时,做的注释,非常详细,可以配合我的博客一起阅读。
大并发服务器开发(实战)https://www.bilibili.com/video/av45560719课程的所有ppt和代码资料,里面还有muduo网络库的使用手册
Muduo - A reactor-based light weight C++ network library CentOS5.5 兼容性修改
基于muduo网络库的集群聊天服务器和客户端源码,使用nginx tcp负载均衡,mysql 基于muduo网络库的集群聊天服务器和客户端源码,使用nginx tcp负载均衡,mysql数据库,redis发布-订阅数据库,redis发布-订阅 基于...
集群聊天服务器(nginx tcp负载均衡模块、muduo网络库、基于发布-订阅的redis消息队列、mysql数据库) 集群聊天服务器(nginx tcp负载均衡模块、muduo网络库、基于发布-订阅的redis消息队列、mysql数据库) 集群聊天...
开源项目2-muduo-master.rar
Linux多线程服务器编程 书中的一些代码
聊天服务器 可以工作在nginx tcp负载均衡环境中的合并聊天服务器和客户端源码基于muduo实现
本内容适用于学习c++网络库如muduo的开发者,资源主要涉及muduo的底层封装如socket、channel、eventloop、tcpserver等内容,相信同学们在阅读完之后能够踏入学习muduo的大门哈!
muduo 是一个基于 Reactor 模式的现代 C 网络库,它采用非阻塞 IO 模型,基于事件驱动和回调,原生支持多核多线程,适合编写 Linux 服务端多线程网络应用程序。视频连接:...
基于muduo开发的集群聊天服务器c++源码+数据库+使用说明.zip 基于muduo开发的集群聊天服务器c++源码+数据库+使用说明.zip 基于muduo开发的集群聊天服务器c++源码+数据库+使用说明.zip 【资源说明】 该项目是个人毕设...
对应 文档下载地址 https://download.csdn.net/download/wumingzcj/10408650
muduo 是一个基于 Reactor 模式的现代 C++ 网络库,它采用非阻塞 IO 模型,基于事件驱动和回调,原生支持多核多线程,适合编写 Linux 服务端多线程网络应用程序
用来分析muduo的reactor结构,怕自己忘了,写个思维导图总结一下
可以工作在nginx tcp负载均衡环境中的集群聊天服务器和客户端源码 基于muduo库实现 redis用于服务器中间件即消息队列 mysql用于保存用户数据 可以工作在nginx tcp负载均衡环境中的集群聊天服务器和客户端源码 基于...
muduo是一个高性能的网络中间件,可以替代原始的socket操作。这里是 muduo-1.0.2.tar.gz程序代码。节省用户寻找的时间。关于如何在嵌入式环境下使用,请参考本人已经上传的说明文档。