一些.NET對(duì)多線程異常處理技巧分享
多線程環(huán)境
在我們的產(chǎn)品 SE 中,出現(xiàn)多線程的地方主要有兩大類,一類是通過(guò) ThreadPool 或 new Thread 主動(dòng)發(fā)起多線程,另一類是 Socket 通訊回調(diào)。
多線程異常捕獲
對(duì)于一般的異常處理來(lái)說(shuō),我們只要簡(jiǎn)單的將可能出錯(cuò)的語(yǔ)句包含在 try/catch 語(yǔ)句中即可。我也曾經(jīng)簡(jiǎn)單的將該方法運(yùn)用于多線程的異常捕獲,結(jié)果并非如此,代碼如下:
public static void Main()
{
try
{
new Thread (Go).Start();
}
catch (Exception ex)
{
// 永遠(yuǎn)執(zhí)行不到這兒!
Console.WriteLine ("Exception!");
}
}
private static void Go()
{
throw null;
}
正確的做法應(yīng)該是在新線程入口方法 Go 中捕獲異常:
public static void Main()
{
new Thread (Go).Start();
}
private static void Go()
{
try
{
...
throw null; // 該異常將會(huì)被捕獲
...
}
catch (Exception ex)
{
// 異常日志記錄,或者通知其他線程出現(xiàn)異常了
...
}
}
以上的正確做法來(lái)自 Threading in C# 中的小節(jié) Exception Handling,該文涉及到 .NET 多線程的方方面面,是我看到最全最好的文章。
正確捕獲多線程異常的方法找到了,接下來(lái)我們自然會(huì)想:是不是每個(gè)線程入口方法都得這么做?
且看 Threading in C# 中的小節(jié) Exception Handling 的描述:從 .NET 2.0 開始,任何一個(gè)線程上未處理的異常都會(huì)導(dǎo)致整個(gè)應(yīng)用程序關(guān)閉。因此,在每個(gè)線程入口方法中都必須要使用 try/catch 語(yǔ)句,至少在產(chǎn)品應(yīng)用程序中必須如此,以免應(yīng)用程序因?yàn)槲覀兾搭A(yù)料到的代碼而關(guān)閉整個(gè)應(yīng)用程序。
如果僅僅記下異常信息而不在乎應(yīng)用程序異常關(guān)閉,那么有兩個(gè)方法可以做到:
1、對(duì)于 Windows Form 程序來(lái)說(shuō),有一個(gè)全局異常處理事件:Application.ThreadException;
2、對(duì)于所有 .NET 程序來(lái)說(shuō),還有一個(gè)更低級(jí)的全局異常處理事件:AppDomain.UnhandledException;
更高的要求
我們能簡(jiǎn)單的通過(guò)全局異常處理事件來(lái)記錄錯(cuò)誤日志;如果保證不中斷應(yīng)用程序,也可以在每個(gè)線程入口方法中捕獲異常并記錄異常日志。有沒(méi)有辦法做到:既能捕獲異常且不中斷應(yīng)用程序,又能如全局異常處理事件那樣簡(jiǎn)單捕獲異常?
對(duì)于主動(dòng)創(chuàng)建的新線程,至少可以做到這一點(diǎn):
public static class ThreadExecutor
{
public static bool Execute(System.Threading.WaitCallback callback, object state)
{
try
{
return System.Threading.ThreadPool.QueueUserWorkItem(callback, state);
}
catch (Exception e)
{
// log the exception
}
return false;
}
}
相關(guān)文章
淺談如何在ASP.NET Core中實(shí)現(xiàn)一個(gè)基礎(chǔ)的身份認(rèn)證
這篇文章主要介紹了淺談如何在ASP.NET Core中實(shí)現(xiàn)一個(gè)基礎(chǔ)的身份認(rèn)證,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。2016-12-12
IIS7偽靜態(tài)web.config配置的方法和規(guī)則
本文主要介紹IIS7上配置偽靜態(tài)的超簡(jiǎn)單的新方法,安裝URLRewrite插件,配置web.config即可。2016-04-04
ASP.NET Core啟動(dòng)地址配置方法及優(yōu)先級(jí)順序
這篇文章主要介紹了ASP.NET Core啟動(dòng)地址配置方法及優(yōu)先級(jí)順序,如果在同一臺(tái)機(jī)器上運(yùn)行多個(gè)ASP.NET Core實(shí)例,使用默認(rèn)值肯定不合適,下面我們一起進(jìn)入文章了解具體內(nèi)容吧2022-03-03
Asp.NetCore3.1開源項(xiàng)目升級(jí)為.Net6.0的方法實(shí)現(xiàn)
自從.Net6.0出來(lái)后,一直想之前開發(fā)的項(xiàng)目升級(jí).Net6.0,本文就詳細(xì)的介紹一下如何將Asp.NetCore3.1開源項(xiàng)目升級(jí)為.Net6.0,感興趣的小伙伴們可以參考一下2021-12-12
asp.net DataTable相關(guān)操作集錦(篩選,取前N條數(shù)據(jù),去重復(fù)行,獲取指定列數(shù)據(jù)等)
這篇文章主要介紹了asp.net DataTable相關(guān)操作,包括篩選,取前N條數(shù)據(jù),去重復(fù)行,獲取指定列數(shù)據(jù)等.基本涵蓋了DataTable的常見(jiàn)操作技巧,需要的朋友可以參考下2016-06-06
Asp.Mvc 2.0用戶服務(wù)器驗(yàn)證實(shí)例講解(4)
這篇文章主要介紹了Asp.Mvc 2.0實(shí)現(xiàn)用戶服務(wù)器驗(yàn)證功能,需要的朋友可以參考下2015-08-08
使用VSCode開發(fā)和調(diào)試.NET Core程序的方法
這篇文章主要介紹了使用VSCode開發(fā)和調(diào)試.NET Core程序的方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-05-05

