改善C#程序的157个建议——建议84学习笔记:使用PLINQ

简介: 改善C#程序的157个建议——建议84学习笔记:使用PLINQ

微软专门为Linq拓展了一个类ParallelEnumerable(该类型也在命名空间System.Linq中),它所提供的扩展方法让Linq支持并行计算,这就是所谓PLinq。


传统的Linq计算是单线程的,PLinq则是并发的、多线程的,例如:


  class Program


   {


       static void Main(string[] args)


       {


           List<int> intList = new List<int>() { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9 };


           var query = from p in intList select p;


           Console.WriteLine("以下是Linq输出:");


           foreach (int item in query)


           {


               Console.WriteLine(item.ToString());


           }


           Console.WriteLine("以下是PLinq并行输出:");


           var queryParallel = from p in intList.AsParallel() select p;


           foreach (int item in queryParallel)


           {


               Console.WriteLine(item.ToString());


           }


           Console.ReadKey();


       }


}


以下是Linq输出:


0


1


2


3


4


5


6


7


8


9


以下是PLinq并行输出:


0


1


9


2


4


6


8


3


5


7


并行输出的另一种方式:


  queryParallel.ForAll((item) => {


               Console.WriteLine(item.ToString());


           });


使用ForAll会忽略掉查询的AsOrdered请求。例:


           Console.WriteLine("以下是PLinq并行顺序输出:");


           var queryParallel = from p in intList.AsParallel().AsOrdered() select p;


           foreach (int item in queryParallel)


           {


               Console.WriteLine(item.ToString());


           }


           Console.WriteLine("以下是PLinq并行ForAll输出:");


           queryParallel.ForAll((item) => {


               Console.WriteLine(item.ToString());


           });


以下是PLinq并行顺序输出:


0


1


2


3


4


5


6


7


8


9


以下是PLinq并行ForAll输出:


9


2


3


8


4


5


6


7


0


1


在并行查询后在进行排序,会牺牲掉一定的性能。一些扩展方法默认对元素进行排序,这些方法包括OrderBy、OrderByDescending、ThenBy和ThenByDescending,还有一些查询方法比如Take。



目录
相关文章
|
27天前
|
缓存 C# Windows
C#程序如何编译成Native代码
【10月更文挑战第15天】在C#中,可以通过.NET Native和第三方工具(如Ngen.exe)将程序编译成Native代码,以提升性能和启动速度。.NET Native适用于UWP应用,而Ngen.exe则通过预编译托管程序集为本地机器代码来加速启动。不过,这些方法也可能增加编译时间和部署复杂度。
|
18天前
|
设计模式 程序员 C#
C# 使用 WinForm MDI 模式管理多个子窗体程序的详细步骤
WinForm MDI 模式就像是有超能力一般,让多个子窗体井然有序地排列在一个主窗体之下,既美观又实用。不过,也要小心管理好子窗体们的生命周期哦,否则一不小心就会出现一些意想不到的小bug
|
30天前
|
XML 存储 安全
C#开发的程序如何良好的防止反编译被破解?ConfuserEx .NET混淆工具使用介绍
C#开发的程序如何良好的防止反编译被破解?ConfuserEx .NET混淆工具使用介绍
44 0
|
1月前
|
C#
C#中的数组型参数学习笔记
C#中的数组型参数学习笔记
25 0
|
1月前
|
安全 API C#
C# 如何让程序后台进程不被Windows任务管理器强制结束
C# 如何让程序后台进程不被Windows任务管理器强制结束
58 0
|
2月前
|
C# 容器
C#中的命名空间与程序集管理
在C#编程中,`命名空间`和`程序集`是组织代码的关键概念,有助于提高代码的可维护性和复用性。本文从基础入手,详细解释了命名空间的逻辑组织方式及其基本语法,展示了如何使用`using`指令访问其他命名空间中的类型,并提供了常见问题的解决方案。接着介绍了程序集这一.NET框架的基本单位,包括其创建、引用及高级特性如强名称和延迟加载等。通过具体示例,展示了如何创建和使用自定义程序集,并提出了针对版本不匹配和性能问题的有效策略。理解并善用这些概念,能显著提升开发效率和代码质量。
92 4
|
1月前
|
API C#
C#实现Winform程序右下角弹窗消息提示
C#实现Winform程序右下角弹窗消息提示
68 0
|
2月前
|
Linux C# 开发者
Uno Platform 驱动的跨平台应用开发:从零开始的全方位资源指南与定制化学习路径规划,助您轻松上手并精通 C# 与 XAML 编程技巧,打造高效多端一致用户体验的移动与桌面应用程序
【9月更文挑战第8天】Uno Platform 的社区资源与学习路径推荐旨在为初学者和开发者提供全面指南,涵盖官方文档、GitHub 仓库及社区支持,助您掌握使用 C# 和 XAML 创建跨平台原生 UI 的技能。从官网入门教程到进阶技巧,再到活跃社区如 Discord,本指南带领您逐步深入了解 Uno Platform,并提供实用示例代码,帮助您在 Windows、iOS、Android、macOS、Linux 和 WebAssembly 等平台上高效开发。建议先熟悉 C# 和 XAML 基础,然后实践官方教程,研究 GitHub 示例项目,并积极参与社区讨论,不断提升技能。
56 2
|
3月前
|
缓存 NoSQL Redis
【Azure Redis 缓存】C#程序是否有对应的方式来优化并缩短由于 Redis 维护造成的不可访问的时间
【Azure Redis 缓存】C#程序是否有对应的方式来优化并缩短由于 Redis 维护造成的不可访问的时间