在VB.NET中正确使用async / await?

时间:2013-09-11 20:24:30

标签: .net vb.net asynchronous

以下代码无法使用错误编译:{{1​​}}

Value of type 'System.Threading.Tasks.Task(Of System.Data.DataTable)' cannot be converted to 'System.Data.DataTable

有人可以告诉我这里可能做错了吗? Private m_country_dt As DataTable = getCountriesAsync() Private Async Function getCountriesAsync() As Task(Of DataTable) Dim dt As DataTable = Await Task(Of DataTable).Factory.StartNew(Function() getCountries_dt()) Return dt End Function Private Function getCountries_dt() As DataTable Dim sp As New dbCore.StoredProcedure Return sp.GetAllCountries() End Function 是一个查询SQL数据库以查找其中所有国家/地区的函数,并在GetAllCountries中返回此函数。此代码位于模块内部。

1 个答案:

答案 0 :(得分:3)

您必须Await才能打开Task (Of DataTable)

另一方面,你应该prefer Task.Run over Task.Factory.StartNew(我在博客上描述了原因)。虽然在这种情况下,我会尝试使用ADO.NET异步方法,而不是仅仅在后台任务上运行同步方法。