博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
actor-based programming与构建大规模扩展性的并行系统
阅读量:7020 次
发布时间:2019-06-28

本文共 913 字,大约阅读时间需要 3 分钟。

1.actor-based  programming

 actor based 类似于object based ,但是它比object 多了自己的message queue 和message processor、message handler

也就是说一个actor是一个独立的处理单元,但是他不是真正的物理上的thread

可以看成是轻量级的thread。

一个actor可以给另一个actor push msg

这样系统中就可以存在大量的独立活动单元,是并行系统的基本组件。

2.Intel TBB(Threading Build Block)

这是intel的一个开源的高性能线程库,它可以很大效率的支持多个任务的并行(这是隐藏实际的物理的thread的),我们可以把上面的actor分配给TBB去调度管理,来实现高性能的并行系统。

这个库还提供了各种thread-safe的container,而我们知道标准c++的stl的container都是线程不安全的。

 

感想

这种actor-based方法让我想到了QT中的Qwidget,他们可以互相通信,有各自的message queue,但是不同的是Qwidget是单线程的,没有一个多线程库去对他们之间做并发。

 

使用actor-based方法构建并行系统,比我们单纯使用多线程来实现的好处是:

1.纯多线程的系统受线程数量的影响,当系统复杂度提高时,线程数目要升高,会降低性能甚至不能扩展系统。

2.纯多线程的系统一般要使用lock critical area等来对线程进行互斥,当系统复杂度提升时,各种dead lock等问题也会出来,降低性能。而actor-based是share nothing的,一个actor里面的数据是相互独立的,不必使用线程间的互斥和等待。

但是个人认为这种情况是理想的,有时还是要用锁的,关于这个,现在有一种transactional memory的东西来实现无锁的多线程并发,不过还处于实验阶段。

转载于:https://www.cnblogs.com/weizhixiao/archive/2013/03/28/5697324.html

你可能感兴趣的文章
Analysis by Its History Exercise 2.3
查看>>
键盘各种按键对应的ASII码
查看>>
[转载]SharePoint 2013测试环境安装配置指南
查看>>
准备开始学习了。
查看>>
6.简单提取小红书app数据保存txt-2
查看>>
REST FUL架构读后感
查看>>
fushioncharts 使用教程要点---使用JSON数据方式
查看>>
阿里云建站流程
查看>>
NSDateFormatter相关整理
查看>>
Sencha 中文站
查看>>
Cygwin下软件安装 - apt-cyg
查看>>
当安装mongodb客户端出现了Failed to load list of databases
查看>>
python基础--内置函数filter,reduce
查看>>
C 学习笔记
查看>>
20165324 Java实验三 敏捷开发与XP实验
查看>>
hdu 4812 DTree (点分治)
查看>>
2015 多校联赛 ——HDU5289(二分+ST)
查看>>
数据结构与算法-链表
查看>>
Socket原理解析2
查看>>
redis数据过期策略【转】
查看>>