我有一个项目,我试图在构造函数中填充一些数据:
public class ViewModel
{
public ObservableCollection<TData> Data { get; set; }
async public ViewModel()
{
Data = await GetDataTask();
}
public Task<ObservableCollection<TData>> GetDataTask()
{
Task<ObservableCollection<TData>> task;
//Create a task which represents getting the data
return task;
}
}
不幸的是,我遇到了一个错误:
The modifier
async
is not valid for this item
当然,如果我包装一个标准方法并从构造函数中调用它:
public async void Foo()
{
Data = await GetDataTask();
}
它工作正常。同样,如果我使用旧的由内而外的方式
GetData().ContinueWith(t => Data = t.Result);
这也行。我只是想知道为什么我们不能直接从构造函数中调用 await
。可能有很多(甚至是明显的)边缘案例和反对它的理由,我只是想不出任何。我也在四处寻找解释,但似乎找不到任何解释。
最佳答案
由于无法创建异步构造函数,因此我使用静态异步方法返回由私有(private)构造函数创建的类实例。这不是很优雅,但可以正常工作。
public class ViewModel
{
public ObservableCollection<TData> Data { get; set; }
//static async method that behave like a constructor
async public static Task<ViewModel> BuildViewModelAsync()
{
ObservableCollection<TData> tmpData = await GetDataTask();
return new ViewModel(tmpData);
}
// private constructor called by the async method
private ViewModel(ObservableCollection<TData> Data)
{
this.Data = Data;
}
}
关于c# - 构造函数可以异步吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46849157/