首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在`IAsyncEnumerable`上并行Linq?

在`IAsyncEnumerable`上并行Linq?
EN

Stack Overflow用户
提问于 2020-04-21 15:07:59
回答 1查看 375关注 0票数 1

是否有官方或稳定的第三方库支持在IAsyncEnumerable<T>上使用AsParallel (.NET标准2.1)?

我不想因为额外的开销而使用异步方法、TaskCompletionSource或其他方法将IAsyncEnumerable<T>包装到IEnumerable<Task<T>>中。

EN

回答 1

Stack Overflow用户

发布于 2020-04-21 16:20:18

将并行和异步结合起来没有多大意义。并行的目的是同时使用多个处理器/核心,而异步的目的是根本不使用任何CPU资源。

AsParallel (PLINQ)在枚举IEnumerable占用大量IEnumerable的情况下与IEnumerable一起使用。换句话说,当在一次MoveNext调用和下一次调用之间必须执行许多条CPU指令时。对于IAsyncEnumerable,延迟(通常)不是由调用MoveNextAsync方法本身引起的,而是由等待返回的ValueTask引起的。等待可等待的对象不会消耗任何CPU资源。你无法控制它什么时候能完成。以Task.Delay(1000)为例。它将在不超过一秒的时间内完成,您不能强迫它在半秒内完成,除非您找到一种方法以某种方式弯曲spacetime。?

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/61337778

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档