前文传送门 dotNET开发系列 之前在实际工作中,遇到过这样的问题,异步获取 GPS 定位信息。一个实际的问题出现了,在第一次定位的时候一般时间都比较长,现在的要做的是,当超出一定的时间,就提醒用户。 那么如何实现异步等待任务并在超时时进行一定的处理呢? Task 的实例方法 Waitpublic bool Wait(int millisecondsTimeout, CancellationToken cancellationToken); Wait 方法所支持的的特点:一个是取消任务,一个是超时。但是不可避免的是阻塞线程,一般在主线程中(UI 线程)是要避免耗时任务的。如果真要去等待获取定位信息的 Task,会不可避免地卡住界面,用户体验不够良好。 Task 的静态方法
var resultTask = Task.WhenAny(task, Task.Delay(timeout)) 我们再 WhenAny 方法中代入两个 task 参数:源 task、新建的延迟的 task(ps:即超时的时间 task),再得到 resultTask。 // 摘要:任何提供的任务已完成时,创建将完成的任务。 异步 Task 实现超时处理的方法Task.WhenAny(task, Task.Delay(timeout)),再比较这两个 Task 的执行先后。实现代码如下: public static async Task<TResult> WaitAsync<TResult>(Task<TResult> task, TimeSpan timeout) 思考上述方法所实现的等待一个获取 gps 的耗时任务,是没有任何问题的。并不会产生性能、卡界面等问题,但是如果在源 task(ps:执行获取 gps 的 task),在超时到期之前完成,则不会取消在 Task.Delay 调用中启动的内部计时器作业。当调用多次该方法时,“僵尸”计时器作业的数量变得越来越大时。性能可能会受到影响 相关链接https://devblogs.microsoft.com/pfxteam/crafting-a-task-timeoutafter-method/ https:///questions/4238345/asynchronously-wait-for-taskt-to-complete-with-timeout 参考资料Task.ContinueWith: http://msdn.microsoft.com/en-us/library/dd270696.aspx [2]Task.Wait: http://msdn.microsoft.com/en-us/library/dd235606.aspx |
|
来自: dotNet全栈开发 > 《编程提升》