Proactor模式结构

Proactor_Structures-600x285
Proactor主动器模式包含如下角色:

Handle 句柄;用来标识socket连接或是打开文件;

Asynchronous Operation Processor:异步操作处理器;负责执行异步操作,一般由操作系统内核实现;

Asynchronous Operation:异步操作

Completion Event Queue:完成事件队列;异步操作完成的结果放到队列中等待后续使用

Proactor:主动器;为应用程序进程提供事件循环;从完成事件队列中取出异步操作的结果,分发调用相应的后续处理逻辑;

Completion Handler:完成事件接口;一般是由回调函数组成的接口;

Concrete Completion Handler:完成事件处理逻辑;实现接口定义特定的应用处理逻辑;

Proactor模式时序图

Proactor_working_process-600x307

  1. 应用程序启动,调用异步操作处理器提供的异步操作接口函数,调用之后应用程序和异步操作处理就独立运行;应用程序可以调用新的异步操作,而其它操作可以并发进行。

  2. 应用程序启动Proactor主动器,进行无限的事件循环,等待完成事件到来。

  3. 异步操作处理器执行异步操作,完成后将结果放入到完成事件队列。

  4. 主动器从完成事件队列中取出结果,分发到相应的完成事件回调函数处理逻辑中。