gpt4 book ai didi

c# - 使用 Task.WhenAll 与 BlockingCollection 产生的无限任务

转载 作者:太空狗 更新时间:2023-10-29 21:08:41 28 4
gpt4 key购买 nike

我正在将后台任务添加到阻塞集合(在后台添加)。

我正在等待 Task.WhenAll 在 GetConsumingEnumerable 返回的 Enumerable 上。

我的问题是:接收 IEnumerable 的 Task.WhenAll 的重载是否“准备好”可能接收无穷无尽的任务?

我只是不确定我是否可以这样做,或者它是否应该以这种方式使用?

private async Task RunAsync(TimeSpan delay, CancellationToken cancellationToken)
{
using (BlockingCollection<Task> jobcollection = new BlockingCollection<Task>())
{
Task addingTask = Task.Run(async () =>
{
while (true)
{
DateTime utcNow = DateTime.UtcNow;
var jobs = Repository.GetAllJobs();
foreach (var job in GetRootJobsDue(jobs, utcNow))
{
jobcollection.Add(Task.Run(() => RunJob(job, jobs, cancellationToken, utcNow), cancellationToken), cancellationToken);
}

await Task.Delay(delay, cancellationToken);
}
}, cancellationToken);

await Task.WhenAll(jobcollection.GetConsumingEnumerable(cancellationToken));
}
}

最佳答案

Since your goal is merely to wait until the cancellation token is cancelled ,你应该那个。由于其他人已经解释过的原因,在无限的任务序列上使用 WhenAll 并不是解决这个问题的方法。有更简单的方法来完成永远不会完成的任务。

await new TaskCompletionSource<bool>().Task
.ContinueWith(t => { }, cancellationToken);

关于c# - 使用 Task.WhenAll 与 BlockingCollection 产生的无限任务,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25488574/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com