我是第一次尝试并行编程,我正在使用它来改进Telerik Scheduler控件的速度过滤。
这是我用来按房间过滤约会的代码,例如:
Task.Factory.StartNew(() =>
{
SchedulerView view = this.radScheduler1.ActiveView;
//ConcurrentBag<Classes.Appointment> _bag;
if (InvokeRequired) Invoke((Action)(delegate
{
this.radScheduler1.Appointments.BeginUpdate();
_itemsview = appointments.AsEnumerable().Where(app => app.Start >= view.StartDate && app.End < view.EndDate.AddDays(1)).ToList();
//_bag = new ConcurrentBag<Classes.Appointment>(_itemsview);
Parallel.ForEach(_itemsview, item =>
{
if (_unidades.Contains(item.Room.ToString()))
{
item.Visivel = true;
}
else
{
item.Visivel = false;
}
});
this.radScheduler1.Appointments.EndUpdate();
this.radScheduler1.Select();
}));
});
接下来发生的事情是,我有时会看到其他被过滤掉的约会。我知道过滤的约会总数是正确的,但并不总是我在屏幕上看到正确的约会。发生了什么事?
答案 0 :(得分:0)
通常,您需要更新主线程上的UI元素。即使您使用WPF并在后台线程上更新绑定属性,WPF系统仍然需要将其重新编组回UI。
这意味着,在您的情况下,由于您的“工作”完全更新了UI和绑定属性,因此您最好直接在UI线程上执行此操作。在这种情况下,Parallel.ForEach
可能会使整个操作不稳定并且可能更慢。