[libevent]Reactor反应器设计模式

Reactor模式是一种同步I/O事件处理机制,常用于高性能网络服务器。它将所有I/O事件注册到多路复用器上,事件发生时由Reactor分发给对应的处理器。该模式具有响应快、编程简单、可扩展性和可复用性等优点。Libevent是实现Reactor模式的库,提供了事件多路复用机制的封装。文章介绍了Reactor的组件(事件源、事件多路分发器、Reactor和事件处理程序)以及应用场景。
摘要由CSDN通过智能技术生成

对象行为类的设计模式,对同步事件分拣和派发。别名Dispatcher(分发器) 

Reactor模式是处理并发I/O比较常见的一种模式,用于同步I/O中心思想是将所有要处理的I/O事件注册到一个中心I/O多路复用器上,同时主线程阻塞在多路复用器上;一旦有I/O事件到来或是准备就绪(区别在于多路复用器是边沿触发还是水平触发),多路复用器返回并将相应I/O事件分发到对应的处理器中。

Reactor的事件处理机制

普通函数调用的机制:程序调用某函数->函数执行,程序等待->函数将结果和控制权返回给程序->程序继续处理。而所谓事件驱动,简单地说就是你点什么按钮(即产生什么事件),电脑执行什么操作(即调用什么函数)事件驱动模型,如下图:

 

Reactor释义“反应堆”,是一种事件驱动机制。和普通函数调用的不同之处在于:应用程序不是主动的调用某个API完成处理,而是恰恰相反,Reactor逆置了事件处理流程,应用程序需要提供相应的接口并注册到Reactor上,如果相应的时间发生,Reactor将主动调用应用程序注册的接口,这些接口又称为“回调函数”。使用Libevent也是

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值