news 2026/6/10 19:44:13

1.17 并行集合

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
1.17 并行集合

1.并行集合


1.并行集合

a.在C#中,并行集合(ConcurrentCollections).NET 为多线程/并行编程设计的线程安全集合 b.位于System.Collections.Concurrent命名空间,专门解决普通集合(如List<T>、Dictionary<TKey,TValue>)在多线程 读写时的线程安全问题(普通集合非线程安全,多线程操作会导致数据错乱)

1).ConcurrentDictionary<TKey,TValue>(最常用)a.线程安全的字典,是多线程场景下Dictionary的直接替代,核心优势是原子操作方法 b.避免手动加锁实现"检查 - 添加","更新"等复合操作)
usingSystem;usingSystem.Collections.Concurrent;usingSystem.Threading.Tasks;classConcurrentDictDemo{staticvoidMain(){// 初始化并发字典varconcurrentDict=newConcurrentDictionary<int,string>();// 并行循环(多线程)添加元素Parallel.For(0,100,i=>{// 原子操作:不存在则添加,存在则返回已有值concurrentDict.GetOrAdd(i,$"Value_{i}");// 原子操作:尝试更新(只有当前值匹配时才更新)concurrentDict.TryUpdate(i,$"Updated_{i}",$"Value_{i}");});// 多线程查询Parallel.For(0,100,i=>{if(concurrentDict.TryGetValue(i,outvarvalue)){Console.WriteLine($"Key:{i}, Value:{value}");}});}}

2).ConcurrentQueue<T>线程安全的FIFO队列,适合"生产者线程添加任务,消费者线程处理任务"的场景(如后台任务池)
usingSystem;usingSystem.Collections.Concurrent;usingSystem.Threading;usingSystem.Threading.Tasks;classConcurrentQueueDemo{staticvoidMain(){varqueue=newConcurrentQueue<int>();varcts=newCancellationTokenSource();// 生产者线程:持续添加数据Taskproducer=Task.Run(()=>{inti=0;while(!cts.Token.IsCancellationRequested){queue.Enqueue(i++);Console.WriteLine($"生产:{i-1}");Thread.Sleep(100);}});// 消费者线程:持续消费数据Taskconsumer=Task.Run(()=>{while(!cts.Token.IsCancellationRequested){if(queue.TryDequeue(outintvalue)){Console.WriteLine($"消费:{value}");}Thread.Sleep(150);}});// 运行5秒后停止Thread.Sleep(5000);cts.Cancel();Task.WaitAll(producer,consumer);}}

3).BlockingCollection<T>(增强版生产者-消费者)封装了ConcurrentQueue/ConcurrentBag等底层集合,提供阻塞操作("无数据时消费者阻塞, 队列满时生产者阻塞")和边界 限制(限制集合最大容量),是生产者-消费者场景的一站式解决方案
usingSystem;usingSystem.Collections.Concurrent;usingSystem.Threading;usingSystem.Threading.Tasks;classBlockingCollectionDemo{staticvoidMain(){// 初始化:底层用ConcurrentQueue,最大容量10varblockingCollection=newBlockingCollection<int>(newConcurrentQueue<int>(),10);varcts=newCancellationTokenSource();// 生产者(2个线程)Parallel.For(0,2,producerId=>{inti=0;while(!cts.Token.IsCancellationRequested){intvalue=producerId*1000+i++;// 队列满时会阻塞,直到有空间blockingCollection.Add(value,cts.Token);Console.WriteLine($"生产者{producerId}添加:{value}");Thread.Sleep(200);}});// 消费者(3个线程)Parallel.For(0,3,consumerId=>{try{// 无数据时阻塞,直到有数据或完成添加foreach(varvalueinblockingCollection.GetConsumingEnumerable(cts.Token)){Console.WriteLine($"消费者{consumerId}处理:{value}");Thread.Sleep(300);}}catch(OperationCanceledException){Console.WriteLine($"消费者{consumerId}停止");}});// 运行10秒后停止Thread.Sleep(10000);cts.Cancel();blockingCollection.CompleteAdding();// 标记“添加完成”,消费者遍历结束}}
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/10 12:32:33

1小时搞定!用快马快速验证嵌入式产品创意

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 快速开发一个智能农业传感器节点原型。功能要求&#xff1a;1) 基于低功耗LoRa通信&#xff1b;2) 采集土壤温湿度、光照强度数据&#xff1b;3) 支持太阳能充电&#xff1b;4) 实现…

作者头像 李华
网站建设 2026/6/10 13:53:22

25、数据处理与资源消费全解析

数据处理与资源消费全解析 在数据处理和资源消费的领域中,有许多重要的技术和工具值得我们深入探讨。下面将详细介绍数据序列化、网络资源消费以及 OData 消费等方面的内容。 数据序列化 序列化是将对象实例转换为易于通过网络传输或存储在数据库中的格式的过程。常见的序列…

作者头像 李华
网站建设 2026/6/10 13:56:38

5个必学的Python运行技巧:从脚本到自动化

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 开发一个多模式Python运行器&#xff0c;包含&#xff1a;1. 常规脚本执行模式 2. Jupyter式分块执行模式&#xff08;可指定#%%分隔&#xff09;3. 定时任务模式&#xff08;设置c…

作者头像 李华
网站建设 2026/6/10 13:55:59

零基础入门:10分钟学会用vite-plugin-mock模拟API

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 创建一个面向新手的vite-plugin-mock教学项目&#xff0c;包含&#xff1a;1.基础安装配置步骤 2.3个渐进式示例(简单GET/POST/动态路由) 3.实时修改预览效果 4.常见错误解决方法 5…

作者头像 李华
网站建设 2026/6/9 19:59:16

React Native手势动画开发指南:构建流畅滑动删除交互

React Native手势动画开发指南&#xff1a;构建流畅滑动删除交互 【免费下载链接】react-native-animatable Standard set of easy to use animations and declarative transitions for React Native 项目地址: https://gitcode.com/gh_mirrors/re/react-native-animatable …

作者头像 李华
网站建设 2026/6/10 13:53:23

实现 DeepSeek 超长新闻输出以及图片生成和图表生成的教程

实现 DeepSeek 超长新闻输出以及图片生成和图表生成的教程 本教程介绍如何使用 DeepSeek AI 生成超长新闻文章,并自动插入图片占位符和图表占位符,然后使用 AI 生成图片和图表数据,最终生成多语言(中文、越南语)的完整新闻内容。 核心功能:使用 DeepSeek 整合多篇新闻文…

作者头像 李华