C# CancellationTokenSource 终止线程

咱们在多线程中一般使用一个bool IsExit相似的代码来控制是否线程的运行与终止,其实使用CancellationTokenSource来进行控制更为好用,下面咱们将介绍CancellationTokenSource相关用法。html

C# 使用 CancellationTokenSource 终止线程

使用CancellationTokenSource对象须要与Task对象进行配合使用,Task会对当前运行的状态进行控制(这个不用咱们关心是如何孔控制的)。而CancellationTokenSource则是外部对Task的控制,如取消、定时取消。多线程

下面咱们来看看示例代码函数

  1.     class Program
  2.     {
  3.         //声明CancellationTokenSource对象
  4.         static CancellationTokenSource cancelTokenSource = new CancellationTokenSource();
  5.  
  6.         //程序入口
  7.         static void Main(string[] args)
  8.         {
  9.             Task.Factory.StartNew(MyTask, cancelTokenSource.Token);
  10.  
  11.             Console.WriteLine("请按回车键(Enter)中止");
  12.             Console.ReadLine();
  13.  
  14.             cancelTokenSource.Cancel();
  15.             
  16.             Console.WriteLine("已中止");
  17.             Console.ReadLine();
  18.         }
  19.  
  20.         //测试方法
  21.         static void MyTask()
  22.         {
  23.             //判断是否取消任务
  24.             while (!cancelTokenSource.IsCancellationRequested)
  25.             {
  26.                 Console.WriteLine(DateTime.Now);
  27.                 Thread.Sleep(1000);
  28.             }
  29.         }
  30.     }

运行效果如图测试

CancellationTokenSourceTask.Factory.StartNew 建立并启动了 MyTask 方法,并传递了一个 CancellationTokenSource.Token 对象进去。咱们能够经过在外部CancellationTokenSource对象进行控制是否取消任务的运行。spa

当在 MyTask 中的 cancelTokenSource.IsCancellationRequested 判断若是是取消了任务的话 就跳出while循环执行。也就结束了任务线程

 

咱们还可使用计时取消任务,当一个任务超过了咱们所设定的时间而后自动取消该任务的执行。以下代码所示code

  1.  var cancelTokenSource = new CancellationTokenSource(3000);

除了构造函数,咱们还可使用另一种方式实现定时取消,以下代码所示htm

  1.  cancelTokenSource.CancelAfter(3000);

运行起来效果是同样的,3秒钟定时取消。对象

 

多个 CancellationTokenSource 复合

在有多个CancellationTokenSource须要一块儿并行管理的时候,好比任意一个任务取消 则取消全部任务。咱们没必要去一个一个的去关闭,只须要将须要一块儿并行关闭的CancellationTokenSource组合起来就好了。以下代码所示,执行结果是跟上面的图同样的。我就再也不上图了。get

  1.     class Program
  2.     {
  3.         //声明CancellationTokenSource对象
  4.         static CancellationTokenSource c1 = new CancellationTokenSource();
  5.         static CancellationTokenSource c2 = new CancellationTokenSource();
  6.         static CancellationTokenSource c3 = new CancellationTokenSource();
  7.  
  8.         //使用多个CancellationTokenSource进行复合管理
  9.         static CancellationTokenSource compositeCancel = CancellationTokenSource.CreateLinkedTokenSource(c1.Token, c2.Token, c3.Token);
  10.  
  11.         //程序入口
  12.         static void Main(string[] args)
  13.         {
  14.             Task.Factory.StartNew(MyTask, compositeCancel.Token);
  15.  
  16.             Console.WriteLine("请按回车键(Enter)中止");
  17.             Console.ReadLine();
  18.  
  19.             //任意一个 CancellationTokenSource 取消任务,那么全部任务都会被取消。
  20.             c1.Cancel();
  21.             
  22.             Console.WriteLine("已中止");
  23.             Console.ReadLine();
  24.         }
  25.  
  26.         //测试方法
  27.         static void MyTask()
  28.         {
  29.             //判断是否取消任务
  30.             while (!compositeCancel.IsCancellationRequested)
  31.             {
  32.                 Console.WriteLine(DateTime.Now);
  33.                 Thread.Sleep(1000);
  34.             }
  35.         }
  36.     }

以上代码调用了c1.Cancel();触发了MyTask()方法中的compositeCancel.IsCancellationRequested为true,则取消了任务。因此咱们在全部任务中判断复合的这个CancellationTokenSource对象便可。

 

转载自:http://www.wxzzz.com/689.html

相关文章
相关标签/搜索