libevent详解三(reactor) - Go语言中文社区

libevent详解三(reactor)


1. reactor模式

reactor简介。

reactor:反应器模式,是一个事件分发器,IO多路复用模型。如下图。
在这里插入图片描述
不同的事件,经过reactor,分发给不同的事件处理器去处理。

一个简单的reactor类需要包括如下方面。

  1. 注册某些事件的回调函数。
  2. 事件循环(调用epoll等,获取触发事件)。

libevent中的reactor模型。

已上一节中例子说明:libevent详解二(使用)

  1. 事件注册。
    A. 首先注册监听fd的可读时间(新链接到来时触发)。为函数evconnlistener_new_bind。生成evconnlistener对象时,传入的回调函数connect_func。此步骤即完成了对监听fd的可读事件的回调函数的注册。
    B. 新链接可读时间注册。
    在connect_func中,对新链接注册可读时间的回调函数。代码为:
bufferevent_setcb(bev, read_func, NULL, NULL, NULL);
  1. 事件循环(调用epoll等)。
    例子中,调用函数event_base_dispatch,之后函数调用关系为event_base_dispatch->event_base_loop->epoll_dispatch->epoll_wait
    通过epoll_wait获取触发的events。
版权声明:本文来源CSDN,感谢博主原创文章,遵循 CC 4.0 by-sa 版权协议,转载请附上原文出处链接和本声明。
原文链接:https://blog.csdn.net/u010720564/article/details/106903529
站方申明:本站部分内容来自社区用户分享,若涉及侵权,请联系站方删除。
  • 发表于 2021-05-18 05:35:04
  • 阅读 ( 1098 )
  • 分类:

0 条评论

请先 登录 后评论

官方社群

GO教程

推荐文章

猜你喜欢