任务循环退出的 CancellationTokenSource 和退出标志之间的区别
Difference between CancellationTokenSource and exit flag for Task loop exit
我想知道使用 CancellationTokenSource 结束循环任务和退出标志之间是否有任何区别
CancellationTokenSource:
CancellationTokenSource cancellationTokenSource;
Task loopTask;
void StartLoop()
{
cancellationTokenSource = new CancellationTokenSource();
loopTask = Task.Factory.StartNew(Loop, TaskCreationOptions.LongRunning);
}
void Loop()
{
while (true)
{
if (cancellationTokenSource.IsCancellationRequested)
break;
Thread.Yield();
}
}
void StopLoop()
{
cancellationTokenSource.Cancel();
loopTask = null;
cancellationTokenSource = null;
}
退出标志:
volatile bool exitLoop;
Task loopTask;
void StartLoop()
{
exitLoop = false;
loopTask = Task.Factory.StartNew(Loop, TaskCreationOptions.LongRunning);
}
void Loop()
{
while (true)
{
if (exitLoop)
break;
Thread.Yield();
}
}
void StopLoop()
{
exitLoop = true;
loopTask = null;
}
对我来说,使用 CancellationTokenSource 没有任何意义,顺便说一下,为什么可以将取消令牌作为参数添加到任务工厂?
非常感谢您的回答。
最好的 ragards teamol
- 使用
CancellationToken
允许令牌处理所有必要的同步,因此您不必考虑它。
- 当
Task
由于创建时使用的令牌被标记为已取消而出现故障时,它会将 Task
的状态设置为已取消,而不是出现故障。如果您使用布尔值(并且不抛出),任务实际上将被标记为成功完成,即使它实际上已被取消。
- 与布尔值不同,它是引用类型,因此可以传递对 CTS 的引用并从其他位置取消(或检查)。这是关键,因为这些位置不需要像使用布尔字段那样耦合在一起;决定何时取消操作的代码以及对取消做出反应的任何代码都不需要相互了解。这允许更好的模块化、抽象、更高级别的功能,而不是特定于个别情况等。
- 它为代码增加了增强的语义。
我想知道使用 CancellationTokenSource 结束循环任务和退出标志之间是否有任何区别
CancellationTokenSource:
CancellationTokenSource cancellationTokenSource;
Task loopTask;
void StartLoop()
{
cancellationTokenSource = new CancellationTokenSource();
loopTask = Task.Factory.StartNew(Loop, TaskCreationOptions.LongRunning);
}
void Loop()
{
while (true)
{
if (cancellationTokenSource.IsCancellationRequested)
break;
Thread.Yield();
}
}
void StopLoop()
{
cancellationTokenSource.Cancel();
loopTask = null;
cancellationTokenSource = null;
}
退出标志:
volatile bool exitLoop;
Task loopTask;
void StartLoop()
{
exitLoop = false;
loopTask = Task.Factory.StartNew(Loop, TaskCreationOptions.LongRunning);
}
void Loop()
{
while (true)
{
if (exitLoop)
break;
Thread.Yield();
}
}
void StopLoop()
{
exitLoop = true;
loopTask = null;
}
对我来说,使用 CancellationTokenSource 没有任何意义,顺便说一下,为什么可以将取消令牌作为参数添加到任务工厂?
非常感谢您的回答。
最好的 ragards teamol
- 使用
CancellationToken
允许令牌处理所有必要的同步,因此您不必考虑它。 - 当
Task
由于创建时使用的令牌被标记为已取消而出现故障时,它会将Task
的状态设置为已取消,而不是出现故障。如果您使用布尔值(并且不抛出),任务实际上将被标记为成功完成,即使它实际上已被取消。 - 与布尔值不同,它是引用类型,因此可以传递对 CTS 的引用并从其他位置取消(或检查)。这是关键,因为这些位置不需要像使用布尔字段那样耦合在一起;决定何时取消操作的代码以及对取消做出反应的任何代码都不需要相互了解。这允许更好的模块化、抽象、更高级别的功能,而不是特定于个别情况等。
- 它为代码增加了增强的语义。