默認狀況下,當程序出現異常,將調用about()異常處理函數,直接終止程序。緩存
exit()將刷新緩存區,但不顯示消息。dom
try{}:當代碼塊內出現異常,並不會終止程序,而是將程序跳轉到catch代碼塊,
catch(){}:正常狀況下,catch代碼塊不會執行,只有當程序異常時纔會執行,
throw(){}:此時若是異常程序內使用了throw來處理,則throw會將信息做爲參數傳遞給catch,catch處理信息後繼續執行程序。
一般狀況下,catch經過傳遞類來處理異常。函數
//.h class bad { private: double v1; double v2; public: bad(int a=0,int b=0):v1(0),v2(0){} void msg(){std::cout<<"hmean("<<v1<<","<<v2<<"):"<<"invaliud argument:a=-b;\n"} }; //.c int hmean(int a,int b); int main() { try { c=hmean(a,b); } catch(bad& bg) { bg.msg(); std::cout<<"Error!" continue; } std::cout<<"Bye!"; return 0; } int hnean(int a,int b) { return a/b; }
exception類包含在<exception.h>頭文件中,
exception類是一種異常類的基類,派生出兩種類:logic_error和runtime_error,
logic_error和runtime_error
logic_error描述了典型的邏輯錯誤(可修復),runtime_error描述了運行時錯誤(不可避免)。
logic_error
· domain_error,定義域錯誤,參數超出取值範圍
· invalid_error,無效參數,參數類型錯誤
· length_error,沒有足夠的空間執行操做
· out_of_bounds,索引錯誤
runtime_error
· range_error,值域錯誤,計算結果不在不在函數容許範圍內,但沒有發生上溢錯誤和下溢錯誤
· overflow_error,上溢錯誤,計算結果超出類型能表示的最大值
· underflow_error,下溢錯誤,發生在浮點運算中,通常浮點運算存在最小值,超出這個最小值將發生下溢錯誤
bad_alloc
當使用new致使內存分配問題時,將引起bad_alloc異常,
bad_alloc位於頭文件
try { int* ptr=new int[100000000]; } catch(bad_alloc& ba) { std::cout<<ba.what()<<std::endl; exit(EXIT_FALLURE); }
將異常類做爲嵌套類放在要原類中能夠精簡代碼,加強可讀性。指針
當發生異常try-catch未能捕獲異常時,程序不會當即終止,而是發生如下行爲:
調用unexceptd(),
調用terminate(),
調用about().code
重定向terminate()索引
#include<exception> void myQuit() { std::cout<<"myError!"<<std::endl; exit(5); } //而後在程序開頭使用set_terminate()重定向terminate() set_terminate(myQuit);
類似的unexceptd()也可重定向,可是隻能重定向爲terminate(),about()和exit()來終止程序內存
#include<exception> void myUnexcepted() { //爲了捕獲全部異常,能夠定向爲bad_exception throw std::bad_exception(); } //而後在程序開頭使用set_terminate()重定向terminate() set_unexcepted(myUnexceptd);
爲防止使用new形成內存泄漏,建議使用智能指針。it