返回以下任务时的最佳实践是什么:
public async Task<Command> BuildCommunicationCommand
作为对象:
public Command BuildCommand
我有以下几点:
public Command BuildCommand()
{
return BuildCommunicationCommand().GetAwaiter().GetResult();
}
但是被告知要尽量避免这种情况,并且我应该等待任务,这样我们就不会阻止UI线程。我认为最好的方法是使 BuildCommand 方法异步以及调用它的任何其他方法。这将是一个巨大的变化,对于使用 BuildCommand 的其他类来说并不是真正需要的。我不想通过使用 导致阻塞。结果,因此在这种情况下最好使用ConfigureAwait(false(:
public Command BuildCommand()
{
var Command = BuildCommunicationCommand().ConfigureAwait(false);
return Command.GetAwaiter().GetResult();
}
我可以使用 ConfigureAwait(false( 等待进程完成,然后调用 .GetAwaiter((。GetResult(( 将其作为对象 Command 返回?
这是我第一次使用异步任务,所以如果以上任何一项完全是垃圾,我很抱歉!
可以将对异步方法的调用包装在另一个方法中,该方法等待任务完成,然后返回结果。当然,这会阻止调用 GetData 的线程。但它摆脱了异步"病毒"。像这样:
private string GetData()
{
var task = GetDataAsync();
task.Wait();
return task.Result;
}
private async Task<string> GetDataAsync()
{
return "Hello";
}
不过,您是在询问最佳实践,那就是根据需要将所有内容更改为异步。