C# 任務(wù)的異常和延續(xù)處理
寫在前面
當(dāng)Task在執(zhí)行過程中出現(xiàn)異?;虮蝗∠壤獾那闆r時,為了讓執(zhí)行流程能夠繼續(xù)進行,可以使用延續(xù)方法實現(xiàn)這種鏈?zhǔn)教幚?;還可以針對前置任務(wù)不同的執(zhí)行結(jié)果,選擇執(zhí)行不同的延續(xù)分支方法。子任務(wù)執(zhí)行過程中的任何異常都會被傳遞到延續(xù)方法中進行統(tǒng)一處理,因此而增強了對并行任務(wù)的流程控制。
代碼實現(xiàn)
public static void ContinueWithException()
{
TaskCreationOptions tco = TaskCreationOptions.AttachedToParent;
Task task = Task.Factory.StartNew(() =>
{
Task.Factory.StartNew(() => { throw new Exception(Environment.NewLine + "first exception" + Environment.NewLine); }, tco);
Task.Factory.StartNew(() => { throw new Exception(Environment.NewLine + "second exception" + Environment.NewLine); }, tco);
Task.Factory.StartNew(() => { throw new Exception(Environment.NewLine + "third exception" + Environment.NewLine); }, tco);
}).ContinueWith(t => Console.WriteLine("Message:" + t.Exception.Message + Environment.NewLine), TaskContinuationOptions.OnlyOnFaulted);
task.Wait();
Task task01 = Task.Factory.StartNew(() =>
{
Console.WriteLine("task01 executed.");
});
Task ok1 = task01.ContinueWith(t => Console.WriteLine("Ok"), TaskContinuationOptions.NotOnFaulted);
Task fail1 = task01.ContinueWith(t => Console.WriteLine("Failure:" + t.Exception.Message), TaskContinuationOptions.OnlyOnFaulted);
Task task02 = Task.Factory.StartNew(() =>
{
throw new Exception("task02 executed.");
});
Task ok2 = task02.ContinueWith(t => Console.WriteLine("Ok"), TaskContinuationOptions.NotOnFaulted);
Task fail2 = task02.ContinueWith(t => Console.WriteLine("Failure:" + t.Exception.Message), TaskContinuationOptions.OnlyOnFaulted);
}調(diào)用結(jié)果

如圖,子任務(wù)中分別拋出的三個異常信息都被傳遞到了延續(xù)方法中,程序依然可以繼續(xù)執(zhí)行;另外task01和task02分別根據(jù)執(zhí)行情況進入了不同的延續(xù)分支方法
到此這篇關(guān)于C# 任務(wù)的異常和延續(xù)處理的文章就介紹到這了,更多相關(guān)C# 任務(wù)異常和延續(xù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
DevExpress實現(xiàn)GridControl同步列頭checkbox與列中checkbox狀態(tài)
這篇文章主要介紹了DevExpress實現(xiàn)GridControl同步列頭checkbox與列中checkbox狀態(tài),需要的朋友可以參考下2014-08-08
C#開發(fā)教程之利用特性自定義數(shù)據(jù)導(dǎo)出到Excel
這篇文章主要介紹了C#開發(fā)教程之利用特性自定義數(shù)據(jù)導(dǎo)出到Excel的相關(guān)資料,需要的朋友可以參考下2016-07-07
c#判斷網(wǎng)絡(luò)連接狀態(tài)的示例分享
這篇文章主要介紹了使用c#判斷網(wǎng)絡(luò)連接狀態(tài)的示例,需要的朋友可以參考下2014-02-02

