本文介绍了等待Task.CompletedTask是否意味着异步方法将同步运行?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
static async Task WaitTaskCompleted()
{
//Use Thread A before await Task.CompletedTask
await Task.CompletedTask;
//Will the code after await Task.CompletedTask always use Thread A, or there is chance to have a Thread B?
}
这意味着await Task.CompletedTask
将始终同步执行该方法?
推荐答案
是,此代码将始终同步运行;仅当遇到第一个不完整的可等待时才调用主延续编译器GOO。
您可以在sharplab中看到这一点-特别是这里:
awaiter = Task.CompletedTask.GetAwaiter();
if (!awaiter.IsCompleted)
{
num = (<>1__state = 0);
<>u__1 = awaiter;
<>t__builder.AwaitUnsafeOnCompleted(ref awaiter, ref this);
return;
}
正是AwaitUnsafeOnCompleted(...)
+return
实现了异步性。
这篇关于等待Task.CompletedTask是否意味着异步方法将同步运行?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!