- 1、本文档共20页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
李建忠_多核时代的并行编程 (.NET 4.0)
多核时代的并行编程(.NET 4.0)
多核时代的并行编程(.NET 4.0)
李建忠 祝成科技
lijianzhong@
多核时代的编程挑战
基于多核的
硬件发展趋
势将逼迫软
件不得不走
向并行编程
的道路!
2
并行编程面面观
1.面向对象V.S. 面向并行
对象编程:降低耦合性,提升复用
并行编程:降低资源冲突,提升效率
1.命令式语言V.S. 函数式语言
函数式语言(Functional Language)模型本身可以较好
地解决并发冲突,如:LISP、FP、ML。
命令式语言(Imperative Language)如何解决?特别
是面向对象语言如何在对象模型下解决并发冲突?
2. 自动化工具支持V.S. 程序员手动控制
自动化工具支持:无论是操作系统,抑或是隐式并行编
译器,对于自动获取并行能力的支持都极其有限—— 因
为本质上现代软件体系结构是基于顺序的。
程序员手动控制:具有良好效率的并行程序都需要程序
员手动控制来贴心呵护。
2
并行编程开发基本流程
1.并行性分析
2.并行性表达
3.并行性评估
2
1. 并行性分析
目标问题本身是否具有可并行性?
不具并行性的问题:1个女人需要10个月才
能生产1个小孩,并不代表10个女人花1个
月便可生出一个孩子
具备并行性的问题:10个女人可以在10个
月的时间里生出10个孩子
到底要的是1个孩子?还是10个孩子?
2
2. 并行性表达
任务型并行编程
将总任务划分为各个并行执行的子任务,处理
同一数据。牵扯到竞争与共享问题,需要使用
资源锁。
数据型并行编程
多个并行任务处理的数据相互分离,各并行任
务间通过消息进行通讯。
并发数据结构(共享内存)
线程安全的数据集合,用于实现并发组件。各
任务处理的数据实现内存共享,要求对共享数
据的访问进行同步。
2
3. 并行性评估
正确性评估
效率评估
调试与评测工具
2
.NET平台下并行编程
并行处理所面对的对象:
数据、任务、管道、延迟隐藏……
.NET 1.0 并发编程模型
细粒度、硬编码控制
Thread/ThreadPool
Interlocked/AutoResetEvent/Monitor/Mutex 等
同步对象
异步处理设计模式
.NET 4.0 并行编
文档评论(0)