C#并发编程的实现方式

news/2024/11/29 10:46:23/

一、多线程:是一种并发编程技术,它允许一个应用程序同时执行多个线程。每个线程都有自己的指令集和堆栈,可以在不同的CPU核心上并行运行,或者在一个CPU核心上通过时间片轮转的方式交替运行。多线程的主要优点是可以利用多核处理器的性能,缺点是线程间的同步和通信可能会比较复杂,也可能导致数据竞争等问题。

二、异步:是一种编程范式,它允许操作同时进行而不必等待一个完成后再执行另一个。异步操作可以通过回调函数、Promise、或者语言的async/await语法来实现。异步编程的主要优点是可以提高程序的响应性,避免阻塞主线程,特别适合处理I/O密集型任务,如网络请求、文件读写等。缺点是可能导致代码逻辑复杂,也可能会出现回调地狱等问题。

异步不是多线程。异步和多线程是不同层级的概念,虽然它们在某些情况下可以相互配合实现并发编程。

异步是一种编程模型,任务执行时不会一直占用CPU,而是在遇到I/O操作或者等待其他事件时挂起,在异步操作完成后再恢复任务执行。这种模型可以提高程序的响应性和效率,特别是在处理I/O密集型任务如网络请求或文件读写时。

多线程则是另一种并发编程模型,通过使用多个线程同时执行任务,以提高程序的性能。多线程适合处理CPU密集型任务,因为它可以利用多核处理器的性能。

在某些情况下,异步和多线程可以相互配合使用,例如在异步操作中利用多线程来提高效率,或者在多线程程序中使用异步操作来避免阻塞主线程。但是它们并不能直接等同或互相替代。

.NET提供的处理和并发编程方式:

  1. Task Parallel Library (TPL):TPL是.NET Framework中的一个库,用于编写并行和并发代码。它提供了一组API和工具,可以简化并行编程的复杂性。TPL支持数据并行和任务并行,可以通过Parallel.ForParallel.ForEachParallel.Invoke等方法实现并行循环和并行执行委托。
  2. Parallel LINQ (PLINQ):PLINQ是LINQ的并行版本,它允许在数据集合上执行并行查询操作。通过PLINQ,可以将LINQ查询转换为并行操作,从而提高性能。
  3. Background Worker:Background Worker是.NET中的一个组件,用于在后台线程上执行耗时的操作。它可以在不阻塞UI线程的情况下执行长时间运行的任务,适用于Windows Forms和WPF等应用程序。
  4. Threads and Thread Pools:.NET还提供了对底层线程和线程池的支持。可以使用System.Threading.Thread类创建和管理线程,或者使用System.Threading.ThreadPool类利用线程池资源执行并行操作。
  5. Async/Await:异步编程是另一种处理并发的方式,它可以避免阻塞主线程,提高应用程序的响应性。在.NET中,可以通过异步方法和async/await关键字实现异步编程。异步方法可以在不创建新线程的情况下执行长时间运行的任务,而是通过异步IO、Task等机制实现非阻塞执行。
  6. Dataflow:Dataflow是.NET 4.5中引入的一个库,用于构建基于消息的并行和分布式应用程序。它提供了一组块(Block)类型,可以用于创建消息的生产者和消费者,并通过数据流图(Dataflow Graph)实现并行执行和消息传递。
  7. ** lock-free 和 wait-free 数据结构**:在.NET中,还可以使用lock-free和wait-free数据结构来实现高性能的并发编程。这些数据结构允许多个线程同时访问共享资源,而不需要使用锁或其他同步机制。

具体实现:

1、使用List<Task>

List<Task> tasks = new List<Task>();
foreach (string model in models.Split(','))
{string read_file_name = $"{model}-BOX-{dateTime.ToString("yyyyMMdd")}.csv";string write_file_name = $"{model}-BOX数据生成-{dateTime.ToString("yyyyMMdd")}.csv";tasks.Add(Task.Run(() => { ReadWriteFile(read_file_name,write_file_name); }));
}
Task.WaitAll(tasks.ToArray());//等待List里的Task任务全部执行完成,防止阻塞


http://www.ppmy.cn/news/1129266.html

相关文章

Python数据和Json数据的相互转换

什么是JSON&#xff1f; JSON是一种轻量级的数据交互格式。可以按照JSON指定的格式去组织和封装数据 JSON本质上是一个带有特定格式的字符串 主要功能:JSON就是一种在各个编程语言中流通的数据格式&#xff0c;负责不同编程语言中的数据传递和交互 Python数据和Json数据的相互…

面试问到MySQL模块划分与架构体系怎么办

面试问到Mysql模块划分与架构体系怎么办 文章目录 1. 应用层连接管理器&#xff08;Connection Manager&#xff09;安全性和权限模块&#xff08;Security and Privilege Module&#xff09; 2. MySQL服务器层2.1. 服务支持和工具集2.2. SQL Interface2.3. 解析器举个解析器 …

MATLAB算法实战应用案例精讲-【优化算法】基于房地产市场的优化算法(REMARK)(附MATLAB代码实现)

代码实现 MATLAB main.m clc, clear rng(shuffle) format short e options.nDim = 2; options.nDemander = 80; options.nSupplier = ceil(options.nDemander/4); options.maxFrnd = ceil(options.nDemander/4); options.constrPer = 10; options.KsigmaD = 0.7; options.Ks…

docker-compose 网络配置- IP 主机名 hosts配置

docker-compose 配置IP、hostname、hosts配置 配置IP version: "3" networks:bd-network: # 声明网络external: true services:kafka: # 服务名称networks:bd-network: # 连接的网络名称ipv4_address: 172.2.0.102 # 配置IP配置 主机名 version: "3&quo…

嵌入式Linux应用开发-第七章-野火-正点原子IMX6ULL的LED驱动程序

嵌入式Linux应用开发-第七章-野火-正点原子IMX6ULL的LED驱动程序 野火IMX6ULL的LED驱动程序7.4 野火/正点原子 IMX6ULL的 LED驱动程序7.4.1 原理图7.4.1.1 野火 fire_imx6ull-pro开发板7.4.1.2 正点原子 Atk_imx6ull-alpha开发板 7.4.2 所涉及的寄存器操作7.4.2.1 野火 fire_im…

【MySQL】SQL优化、char、varchar、外键约束、排查慢sql等重点知识汇总

目录 SQL语句 char和varchar比较 SQL语句如何优化 说一下你理解的外键约束 如何排查慢 sql SQL语句 对库操作 创建数据库 create database 数据库名 删除数据库 drop database 数据库名 显示所有数据库 show databases 选中数据库 use 数据库名 对表操作 创建表…

辅助驾驶功能开发-功能对标篇(9)-NOA领航辅助系统-北汽极狐

1.横向对标参数 厂商北汽极狐车型阿尔法S 华为HI版上市时间2022方案13V6R1L+1DMS摄像头前视摄像头4*(双目+长焦+广角)侧视摄像头4后视摄像头1环视摄像头4DMS摄像头1雷达毫米波雷达6*(前+后+四角)4D毫米波雷达/超声波雷达12激光雷达3*(华为96线,905nm)域控供应商1*(华为MDC810)辅…

架构师技能图谱

架构师的技能图谱通常包括以下方面的知识和技能: 1. 系统设计与架构 理解系统设计原则和架构模式,如微服务、分布式系统、单体应用等。能够绘制系统架构图和流程图,使用工具如UML。2. 编程与开发 精通一种或多种编程语言,如Java、Python、C#等。熟悉软件开发最佳实践,包括…