通过任务,可以指定在任务完成之后,应开始运行之后另一个特定任务。例如,一个使用前一个任务的结果的新任务,如果前一个任务失败了,这个任务就应执行一些清理工作。任务处理程序都不带参数或者带一个对象参数,而任务的连续处理方法都有一个Task类型的参数,这里可以访问起始任务的相关信息:

如下面的示例代码: 

   class Program
    {
        static void DoOnFirst()
        {
            Console.WriteLine($"doing some task{Task.CurrentId}");
            Thread.Sleep(3000);
        }
        static void DoOnSecond(Task t)
        {
            Console.WriteLine($"task {t.Id} finished");
            Console.WriteLine($"this task id {Task.CurrentId}");
            Console.WriteLine("doing some cleanup");
            Thread.Sleep(3000);
        }
        static void Main(string[] args)
        {
            Task t1 = new Task(DoOnFirst);
            t1.Start();
            

            Task t2 = t1.ContinueWith(DoOnSecond);
            Task t3 = t1.ContinueWith(DoOnSecond);
            Task t4 = t2.ContinueWith(DoOnSecond);
            Console.ReadKey();
        }
    }
 

连续任务通过在任务上调用ContinueWith()方法来定义。也可以使用TaskFactory类来定义。t1.ContinueWith(DoOnSecond)方法表示,调用DoOnSecond()方法的新任务应在任务t1结束时立即启动。在一个任务结束时,可以启动多个任务,连续任务也可以有另外一个连续任务。如下面的例子所示:

            Task t1 = new Task(DoOnFirst);
            t1.Start();            

            Task t2 = t1.ContinueWith(DoOnSecond);
            Task t3 = t1.ContinueWith(DoOnSecond);
            Task t4 = t2.ContinueWith(DoOnSecond);

使用TaskCreationOptions枚举中的值,可以指定,连续的任务只有在起始任务成功(或者失败)结束时启动。一些可能的值是OnlyOnFaulted、NotOnFaulted 、OnlyOnCanceled、NotOnCanceled和OnlyOnRanToCompletion。

Task t5 = t1.ContinueWith(DoOnError, TaskContinuationOptions.OnlyOnFaulted)

C# Task.ContinueWith 返回对象

使用Task.ContinueWith 可以在Task完成时而继续执行的逻辑

当在ContinueWith中需要返回一个对象时,应该如何使用

 下方代码可以表示,在设置缓存完成后,重新读取缓存,并返回

 var item = await SetCacheItemAsync("key",  cacheItems)
                .ContinueWith<>(async _ => await cacheItem.GetAsync(key));
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。