C#异步编程的实现方式(5)——连续任务
通过任务,可以指定在任务完成后,应开始运行另一个特定任务。任务处理程序或者不带参数或者带一个对象参数,而连续处理程序有一个Task类型的参数。下面先定义两个任务:
static void FirstTaskMethod() { Console.WriteLine(String.Format("Task {0} is doing something", Task.CurrentId)); Thread.Sleep(200); } static void SecondTaskMethod(Task task) { Console.WriteLine("Last task is finished"); Console.WriteLine(String.Format("Task {0} is doing something", Task.CurrentId)); Thread.Sleep(200); }
连续任务通过在任务上调用ContinueWith()方法来现实:
static void Main(string[] args) { Task task1 = new Task(FirstTaskMethod); Task task2 = task1.ContinueWith(SecondTaskMethod); task1.Start(); for (int i = 0; i < 20; i++) { Console.WriteLine("Main thread is running"); Thread.Sleep(200); } Console.Read(); }
主线程循环输出字符串到控制台,Task1任务在另外一个线程里运行,FirstTaskMethod执行完继续SecondTaskMethod,结果如图:
值得注意的是,在一个任务结束时,可以启动多个任务,也就是说,任务的连接可以像一个树结构那样,如下代码:
Task task1 = new Task(FirstTaskMethod); Task task2 = task1.ContinueWith(SecondTaskMethod); Task task3 = task1.ContinueWith(SecondTaskMethod); Task task4 = task2.ContinueWith(SecondTaskMethod); Task task5 = task2.ContinueWith(SecondTaskMethod);
无论前一个任务是如何结束的,后面的连续任务总是在前一个任务结束时启动。TaskContinuationOptions枚举提供了OnlyOnFaulted,NotOnFaulted,OnlyOnCanceled,NotOnCanceled,OnlyOnRunToCompletion几个选项。我们可以指定只有当前一个任务成功结束时才启动:
Task task5 = task2.ContinueWith(SecondTaskMethod, TaskContinuationOptions.OnlyOnRanToCompletion);