新聞中心
處理C++異常問題會在語言級別上遇到少許隱含限制,但在某些情況下,您可以繞過它們。學(xué)習(xí)各種利用異常的方法,您就可以生產(chǎn)更可靠的應(yīng)用程序,本文就對于大多數(shù)用戶頭疼的C++異常問題進行詳細(xì)的剖析與介紹。

堅守“ 做人真誠 · 做事靠譜 · 口碑至上 · 高效敬業(yè) ”的價值觀,專業(yè)網(wǎng)站建設(shè)服務(wù)10余年為成都地磅秤小微創(chuàng)業(yè)公司專業(yè)提供企業(yè)網(wǎng)站制作營銷網(wǎng)站建設(shè)商城網(wǎng)站建設(shè)手機網(wǎng)站建設(shè)小程序網(wǎng)站建設(shè)網(wǎng)站改版,從內(nèi)容策劃、視覺設(shè)計、底層架構(gòu)、網(wǎng)頁布局、功能開發(fā)迭代于一體的高端網(wǎng)站建設(shè)服務(wù)。
在C++中,無論何時在處理程序內(nèi)捕獲一個異常,關(guān)于該異常來源的信息都是不為人知的。異常的具體來源可以提供許多更好地處理該異常的重要信息,或者提供一些可以附加到錯誤日志的信息,以便以后進行分析。
為了解決這一問題,可以在拋出異常語句期間,在異常對象的構(gòu)造函數(shù)中生成一個堆棧跟蹤。ExceptionTracer是示范這種行為的一個類。
在異常對象構(gòu)造函數(shù)中生成一個堆棧跟蹤:
- private:
- class SingleTonTranslator
- {
- public:
- SingleTonTranslator()
- {
- signal(SignalExceptionClass::GetSignalNumber(),
- SignalHandler);
- }
- static void SignalHandler(int)
- {
- throw SignalExceptionClass();
- }
- };
- public:
- SignalTranslator()
- {
- static SingleTonTranslator s_objTranslator;
- }
- };
- // An example for SIGSEGV
- class SegmentationFault : public ExceptionTracer, public
- exception
- {
- public:
- static int GetSignalNumber() {return SIGSEGV;}
- };
- SignalTranslator
- g_objSegmentationFaultTranslator;
- // An example for SIGFPE
- class FloatingPointException : public ExceptionTracer, public
- exception
- {
- public:
- static int GetSignalNumber() {return SIGFPE;}
- };
每當(dāng)進程執(zhí)行一個令人討厭的動作,以致于 Linux? 內(nèi)核發(fā)出一個信號時,該信號都必須被處理。信號處理程序通常會釋放一些重要資源并終止應(yīng)用程序。
在這種情況下,堆棧上的所有對象實例都處于未破壞狀態(tài)。另一方面,如果這些信號被轉(zhuǎn)換成C++ 異常,那么您可以優(yōu)雅地調(diào)用其構(gòu)造函數(shù),并安排多層 catch 塊,以便更好地處理這些信號。
定義的 SignalExceptionClass,提供了表示內(nèi)核可能發(fā)出信號的C++異常問題的抽象。SignalTranslator 是一個基于 SignalExceptionClass 的模板類,它通常用來實現(xiàn)到 C++ 異常的轉(zhuǎn)換。
在任何瞬間,只能有一個信號處理程序處理一個活動進程的一個信號。因此,SignalTranslator 采用了singleton 設(shè)計模式。整體概念通過用于 SIGSEGV 的 SegmentationFault 類和用于 SIGFPE 的FloatingPointException 類得到了展示。
在全局(靜態(tài)全局)變量的構(gòu)造和析構(gòu)期間,每個 ANSI C++ 都捕獲到異常是不可能的。因此,ANSI C++ 不建議在那些其實例可能被定義為全局實例(靜態(tài)全局實例)的類的構(gòu)造函數(shù)和析構(gòu)函數(shù)中拋出異常。#t#
換一種說法就是永遠(yuǎn)都不要為那些其構(gòu)造函數(shù)和析構(gòu)函數(shù)可能拋出異常的類定義全局(靜態(tài)全局)實例。不過,如果假定有一個特定編譯器和一個特定系統(tǒng),那么可能可以這樣做,幸運的是,對于Linux 上的 GCC,恰好是這種情況。
使用 ExceptionHandler 類可以展示這一點,該類也采用了 singleton 設(shè)計模式。其構(gòu)造函數(shù)注冊了一個未捕獲的處理程序。因為每次只能有一個未捕獲的處理程序處理一個活動進程。
構(gòu)造函數(shù)應(yīng)該只被調(diào)用一次,因此要采用 singleton 模式。應(yīng)該在定義有問題的實際全局(靜態(tài)全局)變量之前定義 ExceptionHandler 的全局(靜態(tài)全局)實例。
新聞名稱:輕輕松松解決C++異常問題處理
分享地址:http://fisionsoft.com.cn/article/dppopog.html


咨詢
建站咨詢
