我已经阅读了一些关于此的文章,但我目前并不聪明。我正在处理表单上有TabControl的应用程序。当用户点击标签页时,我希望后台进程能够运行UI线程(因为该过程可能需要几分钟)。这很好,但是如果用户选择不同的选项卡,我希望取消任何当前活动的任务,并注意转到新选项卡。
private void ParentTabControl_SelectedIndexChanged(object sender, EventArgs e)
{
Task testTask;
CancellationTokenSource testSource = new CancellationTokenSource();
CancellationToken testToken = testSource.Token;
switch (ParentTabControl.SelectedIndex)
{
case 0:
updateSummaryTab();
break;
case 1:
testTask = Task.Run(() =>
{
updateTabOne();
}, testToken);
break;
case 2:
updateTabTwo();
break;
}
}
如果我将testSource设置为取消,那么这将不再可用(虽然我知道我将需要使用某种类型的令牌)。我以前为每个选项卡使用不同的BackgroundWorker,只是检查它的IsBusy属性,但我认为使用单个回收的Task可能是更好的选择。
答案 0 :(得分:1)
我得到的问题是当我使用CancellationToken取消任务时,新任务无法启动
为您开始的每一轮工作创建一个新的CTS(和CT)。您需要在字段中存储最后一轮的CTS。然后,开始新的工作是:
if(cts != null) cts.Cancel();
cts = new ...;
StartWork(cts.Token);
请注意,取消正在运行的任务是合作的,并且将令牌传递给Task.Run
不会做任何事情,因为它不会停止已经运行的任务。