C# · 12月 23, 2021

c# – 如果我返回一个Task并且没有等待任何事情,我应该使用async吗?

在异步方法中,代码没有等待任何东西,是否有人将其标记为异步,等待任务,然后返回?

除了潜在的不必要之外,这样做的负面影响是什么?

对于此示例,请假设QueryAsync< int>返回Task< int>.

private static async Task<int> InsertRecord_AsyncKeyword(sqlConnection openConnection){ int autoIncrementedReferralId = await openConnection.QueryAsync<int>(@” INSERT INTO… SELECT CAST(SCOPE_IDENTITY() AS int)” ); return autoIncrementedReferralId;}private static Task<int> InsertRecord_NoAsyncKeyword(sqlConnection openConnection){ Task<int> task = openConnection.QueryAsync<int>(@” INSERT INTO… SELECT CAST(SCOPE_IDENTITY() AS int)” ); return task;}// Top level methodusing (sqlConnection connection = await DbConnectionFactory.GetOpenConsumerAppsqlConnectionAsync()){ int result1 = await InsertRecord_NoAsyncKeyword(connection); int result2 = await InsertRecord_AsyncKeyword(connection);}解决方法 不,你不应该只是在没有等待的情况下向方法添加异步 – 甚至还有编译器警告.

您也不应该在这样的方法中不必要地添加await,因为它会使编译器为该方法生成更复杂的代码,并带来一些相关的性能影响.

从时间的角度来看,两种模式之间没有可观察到的差异 – 任务仍将异步运行,您仍然可以立即等待或稍后在调用者中等待.

我可以想到一个区别 – 如果你直接返回任务,调用者可能会使用ConfigureAwait(false),它将在其他线程上完成.当你等待你内部的任务时,该方法控制执行await之后的代码.

请注意,在最后使用单个等待的方法的成本并没有明显低于没有的方法 – 因此,如果您希望在所有异步方法上编码样式一致使用async,那么除了罕见的时间关键部分之外,它可能很好.