在 C# 中,异步流(Async Streams)通过 IAsyncEnumerable
使用 IAsyncEnumerable 逐个异步产生数据
IAsyncEnumerable
定义一个异步流的方法需返回 IAsyncEnumerable
{
for (int i = 1; i {
await Task.Delay(100); // 模拟异步操作
yield return i;
}
}
用 await foreach 消费异步流
调用方可以使用 await foreach 来消费异步流中的数据,语法类似于普通的 foreach,但不会阻塞主线程。
await foreach (var number in GenerateNumbersAsync()){
Console.WriteLine(number);
}
这种方式适合处理实时数据流,如日志条目、传感器数据或分页 API 响应。
异步流的优势和适用场景
异步流解决了传统集合在大数据量或高延迟 IO 场景下的内存和性能问题。
节省内存:不需要一次性加载所有数据到内存 响应更快:消费者可以立即处理第一批到达的数据 天然支持取消:可通过 CancellationToken 在遍历时中断流 与 LINQ 集成:C# 提供了 AsAsyncEnumerable 等扩展方法支持异步查询基本上就这些。IAsyncEnumerable 让你在处理数据序列时既能保持异步优势,又能像操作集合一样自然。
