• 博客园logo
  • 会员
  • 周边
  • 新闻
  • 博问
  • 闪存
  • 众包
  • 赞助商
  • Chat2DB
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录
ypdxcn
博客园    首页    新随笔    联系   管理    订阅  订阅

actor、reactor与proactor模型:高性能服务器的几种模型概念(转)

 

actor模型:

实体之通过消息通讯,各自处理自己的数据,能够实现这并行。

说白了,有点像rpc。

skynet是actor模型。

reactor模型:

1 向事件分发器注册事件回调

2 事件发生

4 事件分发器调用之前注册的函数

4 在回调函数中读取数据,对数据进行后续处理

libevent是reactor模型。

proactor模型:

1 向事件分发器注册事件回调

2 事件发生

3 操作系统读取数据,并放入应用缓冲区,然后通知事件分发器

4 事件分发器调用之前注册的函数

5 在回调函数中对数据进行后续处理

ASIO是preactor模型。

reactor和proactor的主要区别是,前者应用在回调函数中读取数据,然后进行后续的数据处理;而后者数据读取有操作系统完成,回调函数制作数据处理。

posted @ 2018-07-08 05:04  ypdxcn  阅读(989)  评论(0)    收藏  举报
刷新页面返回顶部
博客园  ©  2004-2026
浙公网安备 33010602011771号 浙ICP备2021040463号-3