news 2026/4/16 10:52:38

1.16 PLINQ

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
1.16 PLINQ

1.PLINQ简介语法

2.PLINQ核心配置

3.PLINQ异常

4.PLINQ取消


1.PLINQ简介语法

PLINQ是LINQ的并行扩展,核心是通过AsParallel()启用并行查询,自动将查询任务分发到多线程池,利用多核CPU提升效率 a.PLINQ依赖System.Linq命名空间,支持内存集合(如List<T>、IEnumerable<T>),不支持LINQ to SQL/EF 等数据库查询 b.启用并行(AsParallel),调用后LINQ查询从"串行"转为"并行"执行
usingSystem;usingSystem.Linq;// 数据源:1~10000 的整数集合varnumbers=Enumerable.Range(1,10000);// 【普通 LINQ(串行)】筛选偶数并乘以 2varserialResult=numbers.Where(n=>n%2==0).Select(n=>n*2).ToList();// 【PLINQ(并行)】仅新增 AsParallel(),其余语法完全一致varparallelResult=numbers.AsParallel()// 启用并行,核心开关.Where(n=>n%2==0).Select(n=>n*2).ToList();// 最终聚合为 List(触发查询执行)

2.PLINQ核心配置

1).控制并行度(WithDegreeOfParallelism)限制并行执行的最大线程数(默认等于CPU逻辑核心数),避免过度并行导致上下文切换varresult=numbers.AsParallel().WithDegreeOfParallelism(4)// 强制最多 4 个线程并行.Sum(n=>n);
2).有序/无序查询(AsOrdered()/AsUnOrdered())a.PLINQ默认无序:并行查询会打乱结果顺序,性能更高 b.保留原集合顺序,需显示调用AsOrdered()-有额外性能开销// 无序(默认):结果顺序随机,性能优varunordered=numbers.AsParallel().Where(n=>n<10).ToList();// 有序:结果顺序与原集合一致,性能略低varordered=numbers.AsParallel().AsOrdered()// 强制保留顺序.Where(n=>n<10).ToList();
3).执行模式(WithExecutionMode())控制PLINQ是否"强制并行"(默认:PLINQ 会自动判断,若任务简单/数据量小,可能降级为串行)varresult=numbers.AsParallel().WithExecutionMode(ParallelExecutionMode.ForceParallelism)// 强制并行(即使PLINQ认为串行更优).Select(n=>n*2).ToList();

3.PLINQ异常

PLINQ会将多线程的异常包装为AggregateException,需捕获并处理
try{varresult=numbers.AsParallel().Select(n=>100/n).ToList();}catch(AggregateExceptionex){// 遍历所有线程的异常foreach(varinnerExinex.InnerExceptions){Console.WriteLine($"异常:{innerEx.Message}");}}

4.PLINQ取消

PLINQ不会强制终止线程,而是在查询执行的"检查点(如每次迭代开始 / 结束)"检查CancellationToken的状态;若令牌标 记为"已取消",则停止新迭代的执行,终止查询 a.CancellationTokenSource(CTS):生成取消令牌的"源头",用于触发取消(调用Cancel()/CancelAfter())b.CancellationToken:由CTS生成,通过WithCancellation()传递给PLINQ,标记取消状态 c.OperationCanceledException:取消触发时抛出的异常(包装在 AggregateException 中)
usingSystem;usingSystem.Linq;usingSystem.Threading;usingSystem.Threading.Tasks;classPLINQCancellationDemo{staticvoidMain(){// 1. 创建取消令牌源(控制取消)varcts=newCancellationTokenSource();// 模拟:在 500ms 后触发取消(另一个线程)Task.Run(()=>{Thread.Sleep(500);Console.WriteLine("触发取消...");cts.Cancel();// 标记令牌为“已取消”});try{// 2. PLINQ 查询关联取消令牌varnumbers=Enumerable.Range(1,1000000);varresult=numbers.AsParallel().WithCancellation(cts.Token)// 核心:关联取消令牌.WithDegreeOfParallelism(4)// 限制并行度// 模拟耗时操作(让查询有足够时间被取消).Select(n=>{// 可选:手动检查令牌(加速取消响应)cts.Token.ThrowIfCancellationRequested();Thread.Sleep(1);// 模拟单次迭代耗时returnn*2;}).ToList();// 触发查询执行Console.WriteLine($"查询完成,结果数:{result.Count}");}catch(AggregateExceptionex){// 3. 处理取消异常(区分取消和其他异常)foreach(varinnerExinex.InnerExceptions){if(innerExisOperationCanceledException){Console.WriteLine("PLINQ 查询已被取消");}else{Console.WriteLine($"其他异常:{innerEx.Message}");}}}finally{// 4. 释放资源(CTS 实现了 IDisposable)cts.Dispose();}}}
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/15 4:00:02

[服务器应用开发教程]第二节-使用java让服务器忙起来

第一部分&#xff1a;为什么是java&#xff1f;如何在liunx上安装java&#xff1f;最核心的一点&#xff1a;java“一次编写&#xff0c;到处运行” 的理念给予了它极为优异的跨平台性能。Java 支持 Linux、Windows、ARM/x86 等环境&#xff0c;并与 Kubernetes、Docker 无缝集…

作者头像 李华
网站建设 2026/4/12 14:37:27

太缺人了!投了AI应用开发岗,仅3小时,邀约不断!

有人发帖分享自己找工作过程中对市场的感知&#xff0c;并立即调整求职策略&#xff0c;从Java后端开发岗转投AI应用开发岗。 通过验证&#xff0c;ta发现&#xff1a;AI应用开发岗真的缺人&#xff0c;双非学历有机会&#xff0c;并且薪资待遇好。 晚上8点-11点&#xff0c;…

作者头像 李华
网站建设 2026/4/14 9:09:56

36、UNIX系统用户管理与公共关系策略

UNIX系统用户管理与公共关系策略 在UNIX系统管理中,用户管理和公共关系是至关重要的两个方面。良好的用户管理能够确保新用户顺利融入系统环境,高效开展工作;而有效的公共关系则有助于提升用户满意度,增强用户对系统管理员的信任。下面我们将详细探讨这两个方面的具体内容…

作者头像 李华
网站建设 2026/4/9 19:41:31

Kotaemon ERP系统对接:SAP/Oracle信息即时查询

Kotaemon ERP系统对接&#xff1a;SAP/Oracle信息即时查询 在大型企业中&#xff0c;每天都有成百上千的员工需要访问ERP系统来获取客户信用额度、订单状态或库存余量。但现实是&#xff0c;大多数人并不熟悉SAP事务码或Oracle EBS的菜单路径&#xff0c;更不用说写SQL查询了。…

作者头像 李华
网站建设 2026/4/12 14:20:49

dify+echart数据可视化

基于difyechart进行数据可视化文档提取器的大模型prompt参数提取器&#xff1a;将大模型提取的csv文档中数据转化为csvdata数据将大模型识别的数据转化为json数据参数提取器&#xff1a;转换为json数据代码执行器&#xff1a;通过解析json数据&#xff0c;填充到echart模版的中…

作者头像 李华
网站建设 2026/4/10 23:23:09

Java面试内卷加剧,普通程序员如何破局?

大家都知道&#xff0c;现在的Java面试是越来越难了&#xff01;主要原因无非是两个&#xff1a;Java比前两年坑少人多&#xff01;大量人才涌入&#xff0c;导致岗位竞争越来越大&#xff0c;面试也就越来越难&#xff01;另外一个&#xff0c;很多公司都宣布倒闭、裁员。加上…

作者头像 李华