学习开源网络库muduo的一点心得

来源:互联网 发布:js file文件上传 编辑:程序博客网 时间:2024/05/17 18:40

最近这一周在学习陈硕的muduo网络库。里面用到了好多回调函数,现在看到第八章,把其中核心的网络模型梳理了一下。

muduo采用的是one loop per thread,也就是使用了IO 多路复用,下面解释其中关键的几个类。

 

EventLoop类。供用户使用,提供一个loop函数。这个函数是IO对路复用的主体函数。

 

Channel类。每一个Channel对应一个fd(文件描述符),包含两个回调函数(由用户去编写)ReadCallBack和WriteCallBack。这是一个基本的操作fd的类,用户可以定义一个新的类包含一个Channel成员,并定义自己的读写回调函数,然后设置为的Channel成员的读写回调函数。每个Channel对象对应一个EventLoop类对象。Channel类的HandleEvent函数来处理所发生的事件,其中revents_代表已发生的事件,由接管它的Poll对象设置。

 

Poller类。保存它所监管的Channel对象。它属于一个EventLoop对,EventLoop的poll函数调用它的poll函数。在没有发生事件时,poll函数阻塞在系统调用poll上。一旦监管的fd中发生事件,系统调用poll函数返回,然后可以得到一个Channel*的列表,代表发生事件的Channel(fd)。然后把这个列表返回给EventLoop,在EventLoop中使用Channel的HandleEvent处理事件。

 Reactor模式的核心内容如下:

0 0
原创粉丝点击