【ArchSummit架构师峰会】探讨数据与人工智能相互驱动的关系>>> 了解详情
写点什么

声明式、命令式以及基于任务的并行化.NET 开发

  • 2007-12-24
  • 本文字数:1543 字

    阅读完需:约 5 分钟

Daniel Moth 发布了四个关于.NET 并行扩展(Parallel Extensions for .NET)的视频,这些内容覆盖了最新为.NET 框架所发布的声明式、命令式以及基于任务的并行化 API。

第一个视频是对架构的总体观察,并且接触了一些示例。尽管这些示例是使用VB 或C#编写的,它们可以在任何.NET 语言中使用。

第二个视频介绍了PLINQ。PLINQ 是一个对XML 和内存对象进行并行查询的声明式的模型。PLINQ 是迄今为止.NET 平台上最容易利用多核特性的做法,只需要修改少许代码即可。

和LINQ 为IEnumerable 对象提供了一套扩展方法一样,PLINQ 为IParallelEnumerable 对象提供了一整套扩展方法。这些扩展在命名上与LINQ 提供的功能一一对应。如果要将一个IEnumerable 对象转换成IParallelEnumerable 对象,只需要调用IEnumerable.AsParallel 方法即可。

如果需要的话,对并行化进行控制也可以通过声明的做法。一些选项,例如是否维持原有的顺序,以及使用多少线程进行处理都可以通过向AsParallel 方法传递不同的参数来进行控制。

使用何种类型的并行处理也会受到查询的执行方式的影响。如果您在查询之上调用了ToList 方法,所有的线程将被分配用于处理这个查询。只有当整个工作结束之后主线程才会继续。这个就是所谓的“停止并前进”过程。

另一方面,如果您对于一个查询使用for-each 循环,那么执行模型将会完全不同。在这个被称为“并行管道”的模型下,主线程将会在另一个线程产出结果的同时进行循环处理。这个模型允许您访问处理过程中的中间状态,当您希望向socket 或文件系统输送数据时会发现这一点非常有用。但是如果您处于一个完全CPU 瓶颈的状况下,这个模型将会比“停止并前进”来的慢。

最后一个方法是反向枚举。一个新的ForAll 方法允许每个线程直接对于每个元素执行某个委托调用。由于您无需等待一个列表生成完毕(停止并前进)或者分配一个线程用于处理循环(并行管道),这可能是最有效率的方法了。

第三个视频有关命令式的并行处理。命令式的并行处理是基于并行版本的Do、For 和For-Each 操作。这些操作都可以接受一个委托,一般可以使用匿名方法的方式来传递。由于VB 不支持多行的匿名方法,C#在这方面有明显的优势。

从表面看来,这套并行库感觉和Fortran 或C 程序员在超级计算机使用的OpenMP 库非常相似。然而,它使用了闭包和线程本地存储来区分共享和隔离的变量。

第四个视频针对并行扩展的核心——任务并行库(Task Parallel Library)。任务并行库,又被称为TPL,本质上是一个高级版本的.NET 线程池。与线程池的功能类似,TPL 能够在线程和处理器之间实现负载均衡。与线程池不同的是,TPL 拥有一套丰富的API,能够支持Thread 类提出的许多概念。

TPL 还拥有一套从前的线程或线程池所不具备的新功能,例如任务拥有一个安全的 Cancel 方法。与 Thread.Abort 方法不同,它不会简单地杀死传递给该任务的工作。如果一个工作还没有分配给一个线程,它只是不会启动而已,否则这个工作会定期检查 Task.IsCancelled 属性。

一个任务的取消操作也可以传递给所有的子任务。不过目前这一点在默认情况下并不会发生,但是开发团队对于社区有关默认情况应该如此的感受很感兴趣。

查看英文原文: Declarative, Imperative, and Task-based Parallelism in .NET - - - - - -

译者简介:赵劼 (Jeffrey Zhao,网名老赵),毕业于复旦大学软件学院,曾任职于微软中国研发中心,现任某创业团队架构师。有 8 年左右的 Web 应用开发和 5 年左右的.NET 应用程序开发经验,对 ASP.NET 企业应用开发与客户端技术(如 JavaScript 和 AJAX 等)有较为深入的理论基础与实践经验,另外,他对 SOA、重构以及程序员能力与修养等相关问题也有着浓厚的兴趣,并且非常希望能够写程序到 60 岁。他的博客为: http://jeffreyzhao.cnblogs.com

2007-12-24 21:45728
用户头像

发布了 157 篇内容, 共 52.6 次阅读, 收获喜欢 6 次。

关注

评论

发布
暂无评论
发现更多内容

计算机接口技术复习题(1-6章)

乌龟哥哥

8月月更

Dockerfile 定制专属镜像

CTO技术共享

【Java·访问修饰符】:default、public、protected、private

翼同学

Java 学习 编程语言 8月月更

iofod——WeUI基础组件解析

独来独往

前端 低代码 开发工具 weui iofod

数据库中存媒体文件的字段用什么类型?一文带你了解二进制大对象BLOB

wljslmz

数据库 8月月更

Python 教程之输入输出(9)—— print() 中的 sep 参数

海拥(haiyong.site)

Python 8月月更

开源一夏 | Qiankun框架对于微前端的解耦和沙盒与实战探索心得

恒山其若陋兮

开源 8月月更

开源一夏 | Python 并发编程之死锁

宇宙之一粟

Python 开源 并发编程 死锁 8月月更

leetcode 594. Longest Harmonious Subsequence 最长和谐子序列(简单).md

okokabcd

LeetCode 算法与数据结构

【CSS】字体样式,包括字体系列、大小、修饰、粗细、简写...

翼同学

CSS 编程语言 8月月更

云原生(二十五) | Kubernetes篇之Kubernetes(k8s)临时存储

Lansonli

云原生 k8s 8月月更

Docker 已运行端口映射怎么破

CTO技术共享

Java并发面试常见考点

浅羽技术

Java 面试 线程 并发 8月月更

头脑风暴:最长回文子序列

HelloWorld杰少

LeetCode 8月月更

Linux 黑客命令装逼小助手

CTO技术共享

精细化资产管理

IT资讯搬运工

【JavaScript】:有关js类型转换的那些事...

翼同学

JavaScript 编程语言、 8月月更 学习分享

豆瓣 TOP3 的 Python 书,千万别错过

图灵教育

Docker下Prometheus和Grafana三部曲之二:细说Docker编排

程序员欣宸

Grafana Prometheus 8月月更

从事DevOps工作应该掌握哪些语言及工具

穿过生命散发芬芳

DevOps 8月月更

悲观锁和乐观锁的区别以及实现方式

浅羽技术

Java 面试 面试题 秋招 8月月更

未来,人人都是创造者

石云升

开源 未来技术趋势 8月月更

Linux热潮下,来呆猫云工作站玩转云上部署Linux工作流新思路

科技怪咖

《 合 成 大 西 瓜 》 重 制 版 !( 联 机 版 在 做 了 )

HullQin

CSS JavaScript html 前端 8月月更

数字化转型别着急,先看看如何打通数据孤岛吧

雨果

数字化转型 打通数据孤岛

【数据结构实践】手把手带你实现 Python 自定义数组

迷彩

开源 数据结构 面向对象 数组操作 8月月更

解决在 Spring Boot 中运行 JUnit 测试遇到的 NoSuchMethodError 错误

HoneyMoose

微博系统“微博评论”高性能高可用计算架构

张立奎

4.0 SDK Workshop 纪实:一起体验多人、多屏幕共享新功能

声网

人工智能 音视频

面试中常用消息中间件对比

浅羽技术

kafka RocketMQ 消息中间件 Rabbit MQ 8月月更

开源一夏 | Python 对象的序列和反序列化

宇宙之一粟

Python 开源 序列化 8月月更

声明式、命令式以及基于任务的并行化.NET开发_.NET_Jonathan Allen_InfoQ精选文章