您好,登錄后才能下訂單哦!
今天就跟大家聊聊有關(guān)怎么解決C++異常問(wèn)題處理,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。
處理C++異常問(wèn)題會(huì)在語(yǔ)言級(jí)別上遇到少許隱含限制,但在某些情況下,您可以繞過(guò)它們。學(xué)習(xí)各種利用異常的方法,您就可以生產(chǎn)更可靠的應(yīng)用程序,本文就對(duì)于大多數(shù)用戶頭疼的C++異常問(wèn)題進(jìn)行詳細(xì)的剖析與介紹。
在C++中,無(wú)論何時(shí)在處理程序內(nèi)捕獲一個(gè)異常,關(guān)于該異常來(lái)源的信息都是不為人知的。異常的具體來(lái)源可以提供許多更好地處理該異常的重要信息,或者提供一些可以附加到錯(cuò)誤日志的信息,以便以后進(jìn)行分析。
為了解決這一問(wèn)題,可以在拋出異常語(yǔ)句期間,在異常對(duì)象的構(gòu)造函數(shù)中生成一個(gè)堆棧跟蹤。ExceptionTracer是示范這種行為的一個(gè)類(lèi)。
在異常對(duì)象構(gòu)造函數(shù)中生成一個(gè)堆棧跟蹤:
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<SegmentationFault> g_objSegmentationFaultTranslator; // An example for SIGFPE class FloatingPointException : public ExceptionTracer, public exception { public: static int GetSignalNumber() {return SIGFPE;} };
每當(dāng)進(jìn)程執(zhí)行一個(gè)令人討厭的動(dòng)作,以致于 Linux? 內(nèi)核發(fā)出一個(gè)信號(hào)時(shí),該信號(hào)都必須被處理。信號(hào)處理程序通常會(huì)釋放一些重要資源并終止應(yīng)用程序。
在這種情況下,堆棧上的所有對(duì)象實(shí)例都處于未破壞狀態(tài)。另一方面,如果這些信號(hào)被轉(zhuǎn)換成C++ 異常,那么您可以優(yōu)雅地調(diào)用其構(gòu)造函數(shù),并安排多層 catch 塊,以便更好地處理這些信號(hào)。
定義的 SignalExceptionClass,提供了表示內(nèi)核可能發(fā)出信號(hào)的C++異常問(wèn)題的抽象。SignalTranslator 是一個(gè)基于 SignalExceptionClass 的模板類(lèi),它通常用來(lái)實(shí)現(xiàn)到 C++ 異常的轉(zhuǎn)換。
在任何瞬間,只能有一個(gè)信號(hào)處理程序處理一個(gè)活動(dòng)進(jìn)程的一個(gè)信號(hào)。因此,SignalTranslator 采用了singleton 設(shè)計(jì)模式。整體概念通過(guò)用于 SIGSEGV 的 SegmentationFault 類(lèi)和用于 SIGFPE 的FloatingPointException 類(lèi)得到了展示。
在全局(靜態(tài)全局)變量的構(gòu)造和析構(gòu)期間,每個(gè) ANSI C++ 都捕獲到異常是不可能的。因此,ANSI C++ 不建議在那些其實(shí)例可能被定義為全局實(shí)例(靜態(tài)全局實(shí)例)的類(lèi)的構(gòu)造函數(shù)和析構(gòu)函數(shù)中拋出異常。
換一種說(shuō)法就是永遠(yuǎn)都不要為那些其構(gòu)造函數(shù)和析構(gòu)函數(shù)可能拋出異常的類(lèi)定義全局(靜態(tài)全局)實(shí)例。不過(guò),如果假定有一個(gè)特定編譯器和一個(gè)特定系統(tǒng),那么可能可以這樣做,幸運(yùn)的是,對(duì)于Linux 上的 GCC,恰好是這種情況。
使用 ExceptionHandler 類(lèi)可以展示這一點(diǎn),該類(lèi)也采用了 singleton 設(shè)計(jì)模式。其構(gòu)造函數(shù)注冊(cè)了一個(gè)未捕獲的處理程序。因?yàn)槊看沃荒苡幸粋€(gè)未捕獲的處理程序處理一個(gè)活動(dòng)進(jìn)程。
構(gòu)造函數(shù)應(yīng)該只被調(diào)用一次,因此要采用 singleton 模式。應(yīng)該在定義有問(wèn)題的實(shí)際全局(靜態(tài)全局)變量之前定義 ExceptionHandler 的全局(靜態(tài)全局)實(shí)例。
看完上述內(nèi)容,你們對(duì)怎么解決C++異常問(wèn)題處理有進(jìn)一步的了解嗎?如果還想了解更多知識(shí)或者相關(guān)內(nèi)容,請(qǐng)關(guān)注億速云行業(yè)資訊頻道,感謝大家的支持。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。