C#异步编程

参考资料:c#文档-微软

简单介绍c#异步编程

在后端开发中。异步编程允许程序在等待某些耗时操作(如网络请求、文件 I/O、数据库查询等)完成时,继续执行其他任务,从而提高程序的性能和响应能力。与同步编程相比,异步编程可以显著减少资源的浪费,提高系统的吞吐量。

与同步编程相比,异步编程的优势

复制代码
提高性能:
    资源利用率:异步编程允许程序在等待耗时操作时释放资源(如 CPU),从而提高资源利用率。
    并发处理:多个异步操作可以并发执行,提高系统的吞吐量。

改善用户体验:
    响应性:在用户界面应用程序中,异步编程可以保持界面的响应性,避免因长时间操作导致的界面卡顿。

避免阻塞:
    非阻塞性:异步编程避免了长时间的阻塞操作,使得程序更加高效和灵活。

应用场景:如果需要 I/O 绑定(例如从网络请求数据、访问数据库或读取和写入到文件系统),/还可以使用 CPU 绑定代码(例如执行成本高昂的计算),都可以编写异步代码。

异步编程的核心是 Task 和 Task 类,这两个对象对异步操作建模。 它们受关键字 async 和 await 的支持。 在大多数情况下模型十分简单:

复制代码
对于 I/O 绑定代码,等待一个在 async 方法中返回 Task 或 Task<T> 的操作。
对于 CPU 绑定代码,等待一个使用 Task.Run 方法在后台线程启动的操作。

async 和 await 关键字

复制代码
async:修饰一个方法,表示该方法是异步的。
await:用于等待一个异步操作完成,而不阻塞当前线程。

Task 和 Task

复制代码
Task:表示一个不返回结果的异步操作。
Task<T>:表示一个返回类型为 T 的异步操作。

示例:待写入

相关推荐
枫叶丹41 小时前
【Qt开发】Qt窗口(九) -> QFontDialog 字体对话框
c语言·开发语言·数据库·c++·qt
海上彼尚2 小时前
Go之路 - 7.go的结构体
开发语言·后端·golang
源代码•宸7 小时前
分布式缓存-GO(分布式算法之一致性哈希、缓存对外服务化)
开发语言·经验分享·分布式·后端·算法·缓存·golang
云和数据.ChenGuang7 小时前
PHP-FPM返回的File not found.”的本质
开发语言·php·运维工程师·运维技术
R.lin8 小时前
Java 8日期时间API完全指南
java·开发语言·python
yangpipi-8 小时前
《C++并发编程实战》 第4章 并发操作的同步
开发语言·c++
火钳游侠8 小时前
java单行注释,多行注释,文档注释
java·开发语言
有趣的我8 小时前
C++ 多态介绍
开发语言·c++
fie88899 小时前
波束赋形MATLAB代码实现
开发语言·matlab
丘狸尾9 小时前
gradio uv无法add
开发语言·python