PLINQ 简介
PLINQ和LINQ的语法基本是差不多的,PLINQ该如何实现并行
var query = from item in source.AsParallel()
where Compute(item) >
select item;
一个简单的AsParallel方法就能实现并行运行,要声明的是AsParallel方法返回的是ParallelEnumerable而不是Enumerable,如GO语言的go关键字一般简单,虽然我怎么学过go语言,但我知道GO关键字绝对不会这么简单,同样PLINQ并行一样不是这么简单,虽然两个不是一个级别的吧。必须要说明的是不要盲目的使用PLNQ,PLINQ会对输入元素进行分区,增加了复杂性,会有一定性能的消耗,通俗的讲就是你select的语句消耗的时间很短,要小于多线程之间频繁切换的时间。
PLINQ 四种分区方式
1、范围分区:对输入的元素根据处理器核数对元素进行平分,元素为实现了IList<T>接口的类型。
2、区块分区:每个线程使用一块区域内的一定数量的元素,区块大小不固定,执行过程中,会动态的进行调整,原则是尽可能保证所有任务同时完成。
3、条带分区:跳过n个元素,处理m个元素,处理完成后跳过n个元素,执行m个元素
4、散列分区:。。。。。。没理解,只知道同3一样是对特定的查询进行优化。
并行执行的算法:管道,停止并运行,反向枚举三种算法。
管道:创建处理器核数+1个线程,一个枚举线程记录状态,其他执行操作
停止并运行:ToList,ToArray等需要完整结果的的操作时使用该方法,但将占用更多的内存
反向枚举:使用AsParallel方法后,调用ForAll方法
PLINQ的并行不是绝对的,下面的列表介绍了 PLINQ 默认情况下将按顺序模式执行的查询形状:
包含 Select 子句、已建立索引的 Where 子句、已建立索引的 SelectMany 子句或 ElementAt 子句的查询(在排序或筛选运算符移除或重新排列了索引后)。
包含 Take、TakeWhile、Skip、SkipWhile 运算符并且源序列中的索引未采用原始顺序的查询。
包含zip或SequenceEquals的查询,除非,其中一个数据源具有原始顺序排列的索引和其他数据源可建立索引(IE.. 数组或ilist(t))。
包含 Concat 的查询,除非将其应用到可建立索引的数据源。
包含 Reverse 的查询,除非应用到可建立索引的数据源。
提到过AsParallel方法返回的是ParallelEnumerable,下面列出ParallelEnumerable中几个方法,是我们更加灵活的使用PLINQ(PD:虽然公司里应该不会用到~)。
AsOrdered和AsUnordered方法,告诉PLINQ结果序列中顺序是否(看的比钱)重要。
AsSequential:强制顺序执行。
AsExecutionMode:强制并行执行。
WithDegreeOfParallelism:指定并行时最大的线程数。
WithMergeOptions:设置PLNQ执行时的缓存类型,建议使用默认模式AutoBuffered。
没有贴多少代码,估计自己以后看都懒的看了,因为我没有从头到尾的敲下来,在图书馆几点知识点回来结合网络就这么整理一下,那么怎么才能用到PLINQ(在代码中查找类似循环能被并行执行的代码,尝试转为并行)。
PLINQ 简介的更多相关文章
- PLinq
PLinq(Linq的并行计算) 上面介绍完了For和ForEach的并行计算盛宴,微软也没忘记在Linq中加入并行计算.下面介绍Linq中的并行计算. 4.0中在System.Linq命名空间下加入 ...
- C#的变迁史 - C# 4.0 之并行处理篇
前面看完了Task对象,这里再看一下另一个息息相关的对象Parallel. Parallel对象 Parallel对象封装了能够利用多核并行执行的多线程操作,其内部使用Task来分装多线程的任务并试图 ...
- 【转】【C#】【Thread】【Parallel】并行计算
并行计算 沿用微软的写法,System.Threading.Tasks.Parallel类,提供对并行循环和区域的支持. 我们会用到的方法有For,ForEach,Invoke. Program.Da ...
- C# 4.0 并行计算部分
C# 4.0 并行计算部分 c#linq算法多线程list微软 目录(?)[-] C 40 并行计算部分 一简单使用 二 并行循环的中断和跳出 三并行循环中为数组集合添加项 四返回集合运算结果 ...
- c#多线程总结(纯干货)
线程基础 创建线程 static void Main(string[] args) { Thread t = new Thread(PrintNumbers); t.Start();//线程开始执行 ...
- [译]何时使用 Parallel.ForEach,何时使用 PLINQ
原作者: Pamela Vagata, Parallel Computing Platform Group, Microsoft Corporation 原文pdf:http://download.c ...
- C#多线程编程系列(一)- 简介
目录 系列大纲 一.前言 二.目录结构 四.章节结构 五.相关链接 系列大纲 目前只整理到第二章,线程同步,笔者后面会慢慢更新,争取能把这本书中精华的知识都分享出来. C#多线程编程系列(一)- 简介 ...
- C# .NET .NET Framework .NET CORE 等的关系简介
2019新的一年,祝大家新年快乐,工作生活一帆风顺,心想事成!诸事大吉! 这篇文章是我今年的第一篇博客,主题是:C# .NET .NET Framework .NET CORE 等这些名词之 ...
- ASP.NET Core 1.1 简介
ASP.NET Core 1.1 于2016年11月16日发布.这个版本包括许多伟大的新功能以及许多错误修复和一般的增强.这个版本包含了多个新的中间件组件.针对Windows的WebListener服 ...
随机推荐
- 导出cluster log
将所有群集节点的日志导出到 clog 目录下: get-clusterlog -destination c:\clog 只导出前10分钟的群集日志: get-cluster -destination ...
- C#-禁止调整窗体的大小
要是想禁止调整窗体的大小,可以查看:FormBorderStyle属性,该属性的设置中有一个"FixedSingle"的选择项,它可以禁止调整窗体的大小.
- USB移动硬盘WinPE启动盘的制作方法
USB移动硬盘WinPE启动盘的制作方法 软件:老九WinPE 老毛桃终于撒手无论版 发行时间:2007年9月11日 制作发行:老毛桃 作用:当系统坏了,无法进入时,用来做系统维护,备份文件.轻巧稳定 ...
- PCL 点云数据操作 OpenCV遍历数据
1.对于点云类型实例cloud,对其第i个点进行赋值操作,使用cloud.point[i].x 和 cloud.point[i].y 和cloud.point[i].z 分别对其XYZ坐标赋值. cl ...
- [Practical Git] Clean up commits with git rebase
Sometimes its nice to clean up commits before merging them into your main code repo; in this lesson, ...
- ios开发——实用技术篇&网络音频播放
网络音频播放 在日常的iOS开发中,我们通常会遇到媒体播放的问题,XCode中已经为我们提供了功能非常强大的AVFoundation框架和 MediaPlayer框架.其中AVFoundation框架 ...
- 用 jQuery Masonry 插件创建瀑布流式的页面(转)
瀑布流式的页面,最早我是在国外的一个叫 Pinterest 的网站上看到,这个网站爆发,后来国内的很多网站也使用了这种瀑布流方式来展示页面(我不太喜欢瀑布流这个名字). 我们可以使用 jQuery 的 ...
- yum -------包安装库
elrepo: http://elrepo.org/tiki/tiki-index.php CentOSPlus: http://wiki.centos.org/zh/AdditionalR ...
- Java设计模式09:单例模式的强化(控制实例个数n)
1. 单例模式的本质: 控制实例数目(目的节约资源) 2. 单例模式体现的一些思想: (1)延迟装载(Lazy Load):懒汉式 (2)缓存:饿汉式 3. 单例模式的变形使用: 控制使用实例个数为3 ...
- 网络请求OkHttp的使用
okHttp: 1.okHttp是squere公司出的,在Android4.0以后盛行 2.httpClient 在5.0中弃用,在6.0以Google的sdk中没有该api 3.httpUrlCo ...