news 2026/5/20 16:30:26

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/5/14 15:23:19

PDF压缩

winnzip项目pdf压缩部分/*** 压缩PDF文件* param inputFile 输入PDF文件路径* param outputFile 输出PDF文件路径* param compressionLevel 压缩等级: 0小尺寸, 1中等尺寸, 2大尺寸* param lossless 是否无损压缩* return 压缩是否成功*/使用Ghostscript命令行方式进行pdf压缩&…

作者头像 李华
网站建设 2026/5/19 0:27:04

国产自主芯片加持!光润通FF-904E-V3.0千兆四光口网卡深度解析与应用场景

在企业级网络、数据中心建设中&#xff0c;网卡作为数据传输的核心枢纽&#xff0c;其性能、稳定性与自主可控性直接决定了整个网络架构的可靠性与安全性。近年来&#xff0c;国产网络硬件崛起&#xff0c;越来越多的企业开始选择自主研发的网络设备。今天就为大家深度解析一款…

作者头像 李华
网站建设 2026/5/20 16:29:09

【开题答辩过程】以《基于python的气象灾害数据分析与可视化系统》为例,不知道这个选题怎么做的,不知道这个选题怎么开题答辩的可以进来看看

个人简介慕婉学姐精通Java、PHP、微信小程序、Python、Golang和安卓开发等语言&#xff0c;擅长开发大数据、深度学习、网站、小程序、安卓应用和算法项目。平时从事项目定制开发、代码讲解、答辩教学和文档编写&#xff0c;也掌握一些降重技巧。感谢大家的持续关注&#xff01…

作者头像 李华
网站建设 2026/5/13 13:54:48

NestJs-拦截器

NestJS 拦截器概述拦截器&#xff08;Interceptor&#xff09;是 NestJS 的核心功能之一&#xff0c;用于在方法执行前后添加额外的逻辑。拦截器基于面向切面编程&#xff08;AOP&#xff09;思想&#xff0c;常用于日志记录、性能监控、响应格式统一等场景。拦截器的核心功能 …

作者头像 李华
网站建设 2026/5/19 2:15:43

谓的“完美本地环境”,是不是开发者体验(DX)最大的谎言?

我扔掉了本地的 Docker 和 VSCode&#xff0c;开发效率反而提升了10倍“在我电脑上明明是好的”&#xff0c;这句话我曾说过无数次&#xff0c;也听过无数次。每次新项目启动或新同事入职&#xff0c;我们总要浪费大量时间在配置开发环境上&#xff0c;过程痛苦且极易出错。我曾…

作者头像 李华
网站建设 2026/5/18 21:52:49

监督学习非监督学习的区别

监督学习&非监督学习监督学习&#xff08;Supervised Learning&#xff09;非监督学习&#xff08;Unsupervised Learning&#xff09;区分——是否有“标签&#xff08;Label&#xff09;”什么是「标签」&#xff1f;监督学习&#xff08;Supervised Learning&#xff09…

作者头像 李华