0

0

c# 异步编程的优缺点

煙雲

煙雲

发布时间:2025-12-31 09:49:49

|

222人浏览过

|

来源于php中文网

原创

异步编程不能提升cpu密集型任务性能,仅优化i/o等待;configureawait(false)在类库中必须使用以防死锁;异常堆栈易失真需手动包装;async void仅限ui事件处理;跨框架兼容性细节需谨慎。

c# 异步编程的优缺点

异步编程不会自动提升 CPU 密集型任务的性能

很多人误以为 async/await 能让计算变快,其实它只优化 I/O 等待时间。比如对一个大数组做排序、图像处理或加密解密,用 Task.Run(() => HeavyComputation()) 包裹后,只是把工作扔到线程池里执行,并不减少总耗时,还增加了调度开销和上下文切换成本。

  • 真正适合 async 的场景:HTTP 请求(HttpClient.GetAsync)、文件读写(File.ReadAllTextAsync)、数据库查询(DbCommand.ExecuteReaderAsync)——这些本质是等待操作系统完成 I/O,期间线程可被复用
  • 若强行把纯计算逻辑标记为 async 且不配合 Task.Run,编译器会警告“此 async 方法缺少 await”,运行时也仍是同步阻塞
  • 高频调用小计算任务时,Task.Run 反而比直接同步执行更慢,因为线程池排队 + 状态机分配有额外开销

ConfigureAwait(false) 不是可有可无的配置项

在类库或底层工具方法中漏掉 ConfigureAwait(false),可能引发死锁或 UI 响应卡顿。它的作用是告诉运行时:await 完成后**不要强制回调回原始同步上下文**(比如 WinForms 的 UI 线程、ASP.NET Classic 的 HttpContext)。

php中级教程之ajax技术
php中级教程之ajax技术

AJAX即“Asynchronous Javascript And XML”(异步JavaScript和XML),是指一种创建交互式网页应用的网页开发技术。它不是新的编程语言,而是一种使用现有标准的新方法,最大的优点是在不重新加载整个页面的情况下,可以与服务器交换数据并更新部分网页内容,不需要任何浏览器插件,但需要用户允许JavaScript在浏览器上执行。《php中级教程之ajax技术》带你快速

下载
  • ASP.NET Core 默认没有 SynchronizationContext,所以多数情况下不加也不会出问题;但 ASP.NET Framework 或 WPF/WinForms 项目里,如果在 UI 线程调用 GetAwaiter().GetResult() 或错误地用了 .Result,就极易死锁
  • 类库作者必须默认加 ConfigureAwait(false),否则使用者在非 UI 环境引用该库时,可能因意外捕获上下文导致性能下降甚至异常
  • 只有明确需要回到原上下文时才不加——比如更新 WPF 的 TextBox.Text,必须在 UI 线程执行

异常堆容易丢失原始位置

异步方法抛出异常后,堆栈信息会包含状态机内部方法(如 MoveNext),原始调用点可能被掩盖。尤其在多层 await 链路中,InnerException 层级变深,调试时第一眼看不到出错的真实行号。

  • 使用 try/catch 捕获异常时,别只看 e.ToString(),要逐层检查 e.InnerException
  • .NET 5+ 支持 await using 和更清晰的异常传播,但旧项目若还在用 .NET Framework 4.7.2,建议在关键异步入口处手动包装异常:
    try {
        await DoSomethingAsync();
    }
    catch (Exception ex) {
        throw new InvalidOperationException("调用 DoSomethingAsync 失败", ex);
    }
  • 单元测试中用 Assert.ThrowsAsync<t>()</t> 而不是 Assert.Throws<t>()</t>,否则会误判为未抛异常

async void 是仅限事件处理程序的危险选择

async void 方法无法被 await,异常会直接炸到 SynchronizationContext 或进程级,极难捕获。它唯一合理用途是 UI 事件处理器(如 Button_Click)。

  • 永远不要在业务逻辑、工具方法、API 接口里写 async void;应该统一用 async Task
  • Web API 控制器中返回 Task<iactionresult></iactionresult> 是标准做法;写成 async void 会导致请求提前结束、日志缺失、监控失效
  • 测试 async void 方法几乎不可能——没有返回值,没地方 await,只能靠超时或副作用判断,可靠性极低
实际项目里最常被忽略的,是跨框架兼容性细节:比如 ValueTask 在 .NET Core 2.1+ 才稳定支持,老项目升级时若盲目替换 Task,可能引入隐式装箱或生命周期错误;还有 async 方法里用 lock 会编译失败,必须改用 SemaphoreSlim.WaitAsync。这些都不是理论问题,而是上线后才暴露的坑。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
javascriptvoid(o)怎么解决
javascriptvoid(o)怎么解决

javascriptvoid(o)的解决办法:1、检查语法错误;2、确保正确的执行环境;3、检查其他代码的冲突;4、使用事件委托;5、使用其他绑定方式;6、检查外部资源等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

186

2023.11.23

java中void的含义
java中void的含义

本专题整合了Java中void的相关内容,阅读专题下面的文章了解更多详细内容。

125

2025.11.27

硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

1768

2023.10.19

PHP接口编写教程
PHP接口编写教程

本专题整合了PHP接口编写教程,阅读专题下面的文章了解更多详细内容。

569

2025.10.17

php8.4实现接口限流的教程
php8.4实现接口限流的教程

PHP8.4本身不内置限流功能,需借助Redis(令牌桶)或Swoole(漏桶)实现;文件锁因I/O瓶颈、无跨机共享、秒级精度等缺陷不适用高并发场景。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

2338

2025.12.29

java接口相关教程
java接口相关教程

本专题整合了java接口相关内容,阅读专题下面的文章了解更多详细内容。

43

2026.01.19

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

431

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

600

2023.08.10

Golang 测试体系与代码质量保障:工程级可靠性建设
Golang 测试体系与代码质量保障:工程级可靠性建设

Go语言测试体系与代码质量保障聚焦于构建工程级可靠性系统。本专题深入解析Go的测试工具链(如go test)、单元测试、集成测试及端到端测试实践,结合代码覆盖率分析、静态代码扫描(如go vet)和动态分析工具,建立全链路质量监控机制。通过自动化测试框架、持续集成(CI)流水线配置及代码审查规范,实现测试用例管理、缺陷追踪与质量门禁控制,确保代码健壮性与可维护性,为高可靠性工程系统提供质量保障。

48

2026.02.28

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Rust 教程
Rust 教程

共28课时 | 6.5万人学习

PostgreSQL 教程
PostgreSQL 教程

共48课时 | 10万人学习

Git 教程
Git 教程

共21课时 | 4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号