gpt4 book ai didi

c# - Task.Delay 值得取消吗?

转载 作者:太空狗 更新时间:2023-10-29 19:45:09 24 4
gpt4 key购买 nike

我最近使用取消模式重新实现了一大堆异步 WCF 服务方法,我在很多地方都看到过这种模式——你在开始的任务上等待 Task.WhenAny 并且一个任务。延迟。当然,现有任务不可取消,但希望在以后的版本中解决。

在我的例子中,Task.Delay 的默认持续时间由服务设置控制。在绝大多数情况下,结果是希望的任务在规定的时间内完成。设置通常很宽敞。

我见过的大多数(但不是全部)示例都没有取消 Task.Delay。它是如此便宜以至于不值得担心吗?我知道取消会引发异常。如果我取消延迟,我应该处理异常吗?

这是我制作的所有服务方法都通过调用的方法:

private async Task<T> GetOrTimeout<T>( Task<T> task, [CallerMemberName] string caller = "" )
{
using ( var cts = new CancellationTokenSource( ) )
{
try
{
var timeout = GetDelay( cts.Token );
var first = await Task.WhenAny( task, timeout );
if ( first == timeout ) throw new TimeoutException( Properties.Resources.TimeoutOccurredInService.Fmt( caller ) );
cts.Cancel( ); //--> haven't been doing this. Should I?
return await task;
}
catch ( Exception ex )
{
throw LoggedFaultException( ex, caller );
}
}
}

...创建延迟的方法如下所示:

private Task GetDelay( CancellationToken token )
{
return Task
.Delay( Properties.Settings.Default.ServiceMethodTimeout, token )
.ContinueWith( _ => { }, TaskContinuationOptions.ExecuteSynchronously );
}

如果我不取消延迟,我是否会占用资源超过必要的时间?特别是,我担心 WCF 启动以调用服务方法的实例。我担心他们会削减服务配置的并发参数。超时设置非常粗略。不取消似乎很浪费,但这对我来说都是全新的东西。

由于取消涉及异常,并且由于我受过不使用异常来传达状态的培训,这感觉就像我将自己描绘成一些我不完全理解的可怕的反模式。也许 Task.Delay 对我来说不是正确的选择。 感觉我把它弄得比我应该的更复杂。任何有关情况的线索都将不胜感激。

最佳答案

首先,整个问题在性能方面可能可以忽略不计,只有在真实环境中测试后才能考虑。

但是,如果我们深入研究,Task.Delay 会创建一个在特定时间间隔后完成的任务。为此,它创建了一个新的 System.Threading.Timer(实现了 IDisposable),该时间间隔后使用 ThreadPool 线程完成 promise 任务.

如果您“大量”使用 Task.Delay,您可能会浪费大量资源,而这些资源在它们有用之后仍会闲置很长时间。如果您还使用捕获任何引用的委托(delegate)向 Task.Delay 任务添加任何延续,它们也会无缘无故地闲逛。

所以是的,取消任务比让它用完更安全,尽管可能不会太多。

关于c# - Task.Delay 值得取消吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32426944/

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