以下代码无法使用错误编译:{{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
中返回此函数。此代码位于模块内部。
答案 0 :(得分:3)
您必须Await
才能打开Task (Of DataTable)
。
另一方面,你应该prefer Task.Run
over Task.Factory.StartNew
(我在博客上描述了原因)。虽然在这种情况下,我会尝试使用ADO.NET异步方法,而不是仅仅在后台任务上运行同步方法。