Reactor模式也叫做反应堆. 其中心思想 : 将要处理的IO事件注册到一个中心处理接口的IO多路复用上, 由回调函数处理事件. 其实就是将select
, poll
, epoll
等使用统一接口进行封装, 注册其回调函数, 等待事件到来时直接调用回调函数.
(图片来源)
处理机制
-
普通函数调用机制
普通函数的调用机制其实就是函数被调用, 将参数封装成栈帧压栈 -> 函数调用 -> 结果压栈 -> 函数返回, 将控制权交给主程序.
-
Reactor模式调用机制
处理函数被注册 -> 事件发生后 -> 主动调用注册的处理函数(从
Reactor
中调用).
Reactor
模式主要的不同就在于事件注册后不再由主程序直接调用, 而事件来的时候才主动有Reactor
调用.
举个栗子 : 平时写作业, 你可能想要抄别人的答案, 你并不知道对方什么时候写完所以你打算每隔一小时问一次“你写完没有”, 这样对方可能4,5小时后才写完, 而你就要问4-5次“你写完没有”. 而Reactor
模式就像你告诉对方你写完通知我一声(其实就是函数注册), 几小时后对方写完了通知你, 你就知道对方写完了(回调).