加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

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

发布时间:2020-12-15 07:22:06 所属栏目:百科 来源:网络整理
导读:一、概述 Reactor反应器模式是一个事件驱动,有一个或多个并发源,有一个业务处理器和多个请求处理器的模式,如图 假设一个场景: 长途客车在路途上,有人上车有人下车,但是乘客总是希望能够在客车上得到休息。 传统的做法是: 每隔一段时间(或每一个站)

一、概述

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

假设一个场景:

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

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

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

上类图,序列图

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

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

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

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读