I/O多路复用——Reactor模式

一、概述

    Reactor反应器模式是一个事件驱动,有一个或多个并发源,有一个业务处理器和多个请求处理器的模式,如图

175006_XaFy_2247638.png

假设一个场景:

长途客车在路途上,有人上车有人下车,但是乘客总是希望能够在客车上得到休息。

传统的做法是:每隔一段时间(或每一个站),司机或售票员对每一个乘客询问是否下车。

反应器模式做法是:汽车是乘客访问的主体(Reactor),乘客上车后,到售票员(acceptor)处登记,之后乘客便可以休息睡觉去了,当到达乘客所要到达的目的地后,售票员将其唤醒即可。

 

上类图,序列图

175525_uO5S_2247638.png

175535_zC80_2247638.png

1、初始化一个Reactor,初始化一个Handler到EventHandler的MAP,注册每一个EventHandler在里面,留个钩子

2、调用时间循环开始监听,java里是Selector,linux下select/poll,epoll,FreeBSD的kqueue等

3、当监听到某个事件发生时,select返回,Reactor回调对应的EventHandler处理

 

 

转载于:https://my.oschina.net/u/2247638/blog/891198

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值