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

C# 多线程 Task TPL任务并行

先总结一下 之前发展过程的要点
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.kler.cn/a/509310.html

相关文章:

  • ThinkPhp项目解决静态资源请求的跨域问题的解决思路
  • 阿里云通义实验室自然语言处理方向负责人黄非:通义灵码2.0,迈入 Agentic AI
  • 学习记录1
  • js基础---var与let的区别以及const的使用
  • C++速览之智能指针
  • riscv架构下linux4.15实现early打印
  • 七大设计原则之里氏替换原则
  • 2025西湖论剑-babytrace
  • PyTest自学-认识PyTest
  • CVPR 2024 人体姿态估计总汇(3D人体、手语翻译和人体网格恢复/重建等)
  • MySQL8数据库全攻略:版本特性、下载、安装、卸载与管理工具详解
  • 当前目录不是一个git仓库/远程仓库已经有了一些你本地没有的更改
  • flutter 常用UI组件
  • 【JVM-9】Java性能调优利器:jmap工具使用指南与应用案例
  • 数据结构-ArrayList和顺序表
  • SSM课设-学生管理系统
  • 免费送源码:Java+ssm+MySQL 基于PHP在线考试系统的设计与实现 计算机毕业设计原创定制
  • 青少年编程与数学 02-007 PostgreSQL数据库应用 07课题、表的操作
  • 基于金融新闻的大型语言模型强化学习在投资组合管理中的应用
  • 了解 .mgJSON 文件
  • 语音技术在播客领域的应用(2)
  • 网络编程-UDP套接字
  • python学opencv|读取图像(三十五)反阈值处理
  • 上位机知识篇---常见Windows操作
  • PortSwigger靶场练习---第二关-查找和利用未使用的 API 端点
  • 在IDEA中使用通义灵码插件:全面提升开发效率的智能助手