当前位置: 首页 > news >正文

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();// 标记“添加完成”,消费者遍历结束}}
http://www.cnnetsun.cn/news/146430.html

相关文章:

  • 用CUDA驱动快速实现并行计算原型
  • 零基础入门:OWASP ZAP下载安装与首次扫描指南
  • jQuery UI 设计主题
  • 告别IllegalStateException:静态代码分析工具对比评测
  • lis|
  • 微服务容器化部署的3大核心挑战与实战解决方案
  • Kotaemon支持自定义主题皮肤,品牌个性化展示
  • 超长需求处理与流式输出在 Markdown 思维导图编辑器中的应用
  • Charles抓包实战:从零破解APP数据交互全流程
  • FFMPEG SIMD编程深度解析:解锁多媒体处理的性能密码
  • 企业级项目中el-config-provider的7个实战技巧
  • 零基础入门:用Python Web框架建第一个网站
  • Unity AVPRO插件终极指南:高效播放大分辨率视频的完整解决方案
  • 传统vsAI:Flutter开发效率对比实验
  • LuCI开发终极指南:在离线环境中构建OpenWrt管理界面
  • Hutool Java工具库:从零开始的完整安装配置指南
  • 轻松下载网页视频图像:VideoDownloadHelper插件终极指南
  • 别再“邪修”Prompt了!向Claude团队学习如何构建提示词
  • Faceniff入门指南:网络安全基础知识
  • Charles抓包零基础入门:小白也能看懂的网络调试指南
  • SwiftUI动画库深度解析与实战应用指南
  • 基于Kotaemon的舆情分析系统设计架构
  • RAG 是什么?Embedding 是什么?用一个例子讲清楚
  • 如何快速掌握Foremost文件分离工具:Windows版终极指南
  • WampServer 3.1.7:Windows平台终极开发环境解决方案
  • 揭秘AdGuardHome的3大极速匹配算法:从百万规则到微秒响应的终极优化方案
  • 终极iOS自动化测试指南:WebDriverAgent完整使用教程
  • 基于DP动态规划的全局最优能量管理策略——ECVT车辆构型与电量维持型电池SOC策略
  • jQuery UI API 类别 - 特效(Effects)
  • AI写论文哪个软件最好?让数字学伴照亮知识的长夜