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

1、概述java

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

假设一个场景:并发

长途客车在路途上,有人上车有人下车,可是乘客老是但愿可以在客车上获得休息。spa

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

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

 

上类图,序列图select

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

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

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