C# 8.0+ 引入异步流(IAsyncEnumerable)和 await foreach,支持非阻塞式异步枚举;可配合 CancellationToken 实现取消,需 C# 8.0+ 和兼容 SDK(如 net6.0)。

在 C# 8.0 及更高版本中,引入了异步流(async streams)的概念,允许你以异步方式枚举数据流。这特别适用于处理大量数据、I/O 操作或从网络、文件、数据库等逐步获取数据的场景。核心特性之一是 await foreach 循环,它可以消费实现了 IAsyncEnumerable<t></t> 的异步数据源。
什么是 IAsyncEnumerable?
IAsyncEnumerable<t></t> 是一个接口,表示一个可以异步枚举的序列。与传统的 IEnumerable<t></t> 不同,它不会阻塞调用线程,适合用于耗时的数据读取操作。
要创建一个异步流,方法需返回 IAsyncEnumerable<t></t> 并使用 yield return 配合 async IAsyncEnumerable 语法。
示例:定义一个异步流方法
以下是一个模拟逐条返回字符串的异步流:
async IAsyncEnumerable<string> GetDataAsync()<br/>
{<br/>
for (int i = 1; i <= 5; i++)<br/>
{<br/>
await Task.Delay(1000); // 模拟异步延迟<br/>
yield return $"Item {i}";<br/>
}<br/>
}登录后复制
使用 await foreach 消费异步流
要消费上面生成的数据流,使用 await foreach 语法。它会等待每一项可用后再处理,不会阻塞主线程。
示例:使用 await foreach 遍历异步流
await foreach (var item in GetDataAsync())<br/>
{<br/>
Console.WriteLine(item);<br/>
}登录后复制
这段代码每秒输出一条信息,总共五条。整个过程是非阻塞的,适合用于 UI 应用或 Web API 中避免线程挂起。
还木有评论哦,快来抢沙发吧~