adv*_*api 2 c# wpf multithreading caliburn.micro async-await
在使用caliburn micro和telerik控件制作的wpf应用程序中,我有不同的屏幕,从远程服务加载数据,然后在gridview /填充组合框中显示数据.我正在使用sync/await运算符来进行负载检索操作,但我几乎可以肯定它有一些瓶颈.等待我有主UI线程等待与工作线程同步...考虑这个示例
Public class MyViewModel:Screen
{
[omiss]
Public bool IsBusy {get;set;}
Public list<Foo> DropDownItems1 {get;set;}
Public list<Foo2> DropDownItems2 {get;set;}
Public async Void Load()
{
IsBusy =true;
DropDownItems1 = await repository.LoadStates();
DropDownItems2 = await repository.LoadInstitutes();
IsBusy = false;
}
}
Run Code Online (Sandbox Code Playgroud)
在那种情况下,我首先加载任务然后加载第二个没有并行性...我该如何优化它?关于我的IsBusy属性,它通过约定绑定到繁忙指示器,如何正确设置?谢谢
更新#1:
我是真正的代码
public async Task InitCacheDataTables()
{
var taskPortolio = GetPortfolio();
var taskInstitutes = GetInstitutes();
var taskStatus = GetStatus();
var taskCounterparts = GetCounterparts();
var taskCrosses = GetCrosses();
var taskCurrencies = GetCurrencies();
var taskSigns = GetSigns();
await TaskEx.WhenAll(new[] { taskPortolio, taskInstitutes, taskStatus, taskCounterparts, taskCrosses, taskCurrencies, taskSigns });
}
Run Code Online (Sandbox Code Playgroud)
任务就像
private async Task GetPortfolio()
{
try
{
dynamicContainer.SetValue(UserContainerKeyHelper.Portfolios, await commonRepository.GetPortfoliosAsync());
}
catch (Exception ex)
{
errorHandler.HandleErrorAsync(ex);
}
}
private async Task GetInstitutes()
{
try
{
dynamicContainer.SetValue(UserContainerKeyHelper.Institutes, await commonRepository.GetInstitutesAsync());
}
catch (Exception ex)
{
errorHandler.HandleErrorAsync(ex);
}
}
Run Code Online (Sandbox Code Playgroud)
调试时我已经看到所有方法都在MainThread上执行了......不应该是在workerthread上吗?
在那种情况下,我首先加载任务然后加载第二个没有并行性...我该如何优化它?
你想要并发,而不是并行.而不是按顺序等待每个任务,您可以使用Task.WhenAll以下方法等待它们:
public async Task LoadAsync()
{
IsBusy = true;
var firstDropDownItemsTask = repository.LoadStates();
var secondDropDownItemsTask = repository.LoadInstitutes();
await Task.WhenAll(DropDownItems1Task, DropDownItems2Task);
DropDownItems1 = firstDropDownItemsTask.Result;
DropDownItems2 = secondDropDownItemsTask.Result;
IsBusy = false;
}
Run Code Online (Sandbox Code Playgroud)
通过约定绑定到繁忙指示符的IsBusy属性如何正确设置?
通常,通过约定绑定的项目需要实现INotifyPropertyChanged,以便更新已更新值的xaml绑定.