C# 多线程 Task TPL任务并行

server/2025/1/17 7:28:47/

先总结一下 之前发展过程的要点
1: 为了保证多线程正确顺序执行 线程同步
2:== 为了节省操作系统线程资源 线程池 异步 方式管理==

正常来讲 使用这俩个要点 进行使用 多线程可以满足开发使用需求
但是 新的问题产生了
那就是 多个异步操作 需要编写大量的代码 控制线程同步以及异步结果处理逻辑
为了 解决这种情况 ==Task ==来了

Task 也就是 TPL 任务并行库 其实可以理解为 对这个 线程池异步方式一个更抽象的表达
一种隐藏细节的封装,以任务的方式来 替代 异步操作线程之间的交互并且提供相应的api去使用

而大多数情况 对于程序开发而言 对于 线程异步处理具体实现是不需要关注的,关注的是业务的执行逻辑,也就是说 Task的目的很明确 封装底层实现 让程序员更关注业务逻辑层,只需要合理使用Task的方式 确保逻辑上的正确即可,而不是专注在异步操作线程大量代码中

接下来 就是主要讲如何使用Task 的 api

  1. 创建任务 不再是thread类的方式了 有专门的Task类 有3种创建 task.run() \task.factory.startnew()\new task().start()
    正常来讲这种方式创建的线程 都是 属于 线程池 后台线程 如果有 长时间操作的
    也可以通过 Task.Factory.StartNew(() => TaskMethod(“长时间复杂操作单独线程”), TaskCreationOptions.LongRunning); 来设置 单独一个线程
    也可以 task.RunSynchronously();
  2. 阻塞线程 之前通过 join 或者 锁 信号量等 来线程同步 主线程或者子线程之间
    task 的话 可以通过 task.result 来 代替join
  3. 组合任务
    task.ContinueWith 设置执行完之后执行操作
    4.子线程中在创建子线程 必须在 运行时 就先创建 子线程并附加给 父子线程
    5.取消任务 还是老方法 CancellationTokenSource cancle 然后 根据token.IsCancellationRequested 去判断 值得注意的是 如果在 task start之前就有可能存在取消操作 所以需要 var Task = new Task(() => TaskMethod(“Task”, cts.Token), cts.Token); 底层任务传递一次取消标志,然后给任务构造函数再传递一次 那么在取消之后进行start 就会拦住报错 异常 不会进行执行去影响

http://www.ppmy.cn/server/159029.html

相关文章

level(三) filterblock

filterblock用于确定某个key是否存在于某个datablock中,在插入一个key到datablock中时也会插入一个key到filterblock中,filterblock中会记录所有的key,并通过布隆过滤器来确定一个key是否存于这个datablock中。下面来看下filterblock的代码&a…

SQLite 3.48.0 发布,有哪些更新?

SQLite 开发团队于 2025 年 1 月 14 日发布了 SQLite 3.48.0 版本,我们来解读一下新版本的改进功能。 EXPLAIN QUERY PLAN SQLite 使用 EXPLAIN QUERY PLAN 命令获取查询语句的执行计划,新版本改进了执行计划输出结果中的覆盖索引优化信息:…

计算机的错误计算(二百一十三)

摘要 利用大模型计算 实验表明,其输出有 1位正确数字。 刚刚登录了一个新的大模型,之前从未使用过。本节将讨论该大模型在 IEEE 754-2019标准下函数计算的准确性。 例1. 计算 下面是与新的大模型的对话。 点评: (1&#xff…

MySQL SQL优化技巧与原理

前言 随着业务数据量的不断增加,MySQL查询语句的执行效率对程序的运行效率影响逐渐增大。因此,进行SQL优化变得至关重要。本文将结合SQL的执行语句顺序和各种SQL场景,介绍一些常见的MySQL SQL优化技巧及其背后的原理。 一、MySQL SQL执行语…

smart_web 管理端说明

smart_web 操作手册 1. smart_web 是什么? smart_web 是 smart_rtmpd 的付费版本,拥有比免费版本更多的功能支持,基于 web 的管理方式,让您随时随地在大部分设备上都能远程对服务器进行维护管理。smart_web 带有进程守护&#x…

Windows上安装和配置Tabby终端工具并实现远程ssh连接内网服务器

文章目录 前言1. Tabby下载安装2. Tabby相关配置3. Tabby简单操作4. ssh连接Linux4.1 ubuntu系统安装ssh4.2 Tabby远程ssh连接ubuntu 5. 安装内网穿透工具5.1 创建公网地址5.2 使用公网地址远程ssh连接 6. 配置固定公网地址 前言 今天我要给大家分享一个非常实用且强大的开源跨…

npm 方式安装Pyodide 详解

npm 方式安装Pyodide 详解 如何通过 npm 安装 Pyodide 1. 安装 Pyodide 在您的项目中运行以下命令: npm install pyodide这将安装 Pyodide npm 包。 2. 在项目中使用 Pyodide 以下是如何在 JavaScript 或 TypeScript 项目中使用 npm 安装的 Pyodide:…

Linux入门——权限

shell命令以及运行原理 Linux严格意义上说的是一个操作系统,我们称之为“核心(kernel)“ ,但我们一般用户,不能直接使用kernel。 而是通过kernel的“外壳”程序,也就是所谓的shell,来与kernel…