返回介绍

任务并行库 (TPL)

发布于 2025-02-23 23:16:15 字数 1321 浏览 0 评论 0 收藏 0

任务并行库 (TPL) 是 System.Threading 和 System.Threading.Tasks 空间中的一组公共类型和 API。 TPL 的目的是通过简化将并行和并发添加到应用程序的过程来提高开发人员的工作效率。 TPL 动态缩放并发的程度以最有效地使用所有可用的处理器。 此外,TPL 还处理工作分区、 ThreadPool 上的线程调度、取消支持、状态管理以及其他低级别的细节操作。 通过使用 TPL,你可以在将精力集中于程序要完成的工作,同时最大程度地提高代码的性能。

从开始.NET Framework 4,TPL 是编写多线程和并行代码的首选的方法。 但是,并不是所有代码都适合并行化;例如,如果某个循环在每次迭代时只执行少量工作,或它在很多次迭代时都不运行,那么并行化的开销可能导致代码运行更慢。 此外,像任何多线程代码一样,并行化会增加程序执行的复杂性。 尽管 TPL 简化了多线程方案,但我们建议你对线程处理概念(例如,锁、死锁和争用条件)进行基本的了解,以便能够有效地使用 TPL。

相关主题

标题描述
数据并行描述如何创建并行的 forforeach 循环(在 Visual Basic 中为 ForFor Each )。
基于任务的异步编程描述如何通过使用 Parallel.Invoke 隐式创建和运行任务,或通过直接使用 Task 对象显式创建和运行任务。
数据流描述如何使用 TPL 数据流库中的数据流组件处理多项运算,这些运算必须彼此通信,或在数据可用时处理数据。
将 TPL 和其他异步模式结合使用描述如何将 TPL 与 .NET 中的其他异步模式一起使用。
数据和任务并行的潜在问题描述一些常见缺陷以及如何避免它们。
并行 LINQ (PLINQ)描述如何使用 LINQ 查询实现数据并行化。
并行编程.NET 并行编程的顶级节点。

另请参阅

使用 .NET Framework 进行并行编程的示例

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文