有兩個比較基本的問題:
1. 為什么要用異常代替錯誤碼?
錯誤碼的缺點:
1) 默認是可以忽略的,因為調用函數時可以不處理其返回值,從而錯誤處理要依賴于程序員的主動性,而不是程序機制的要求;
2) 不能跨作用域傳送,必須逐層向上轉發,即使中間沒有對錯誤碼進行重新定義;
?
使用異??梢越鉀Q解決這兩個問題:
1) 異常默認是不可忽略的,拋出的異常必須捕獲,否則就會報錯;
2) 異??梢钥缱饔糜騻魉?,從而錯誤的發現和處理被很好地分離開來;
?
?
2. 異常和斷言的區別:
?
異常被捕獲后可以不作處理,程序從捕獲位置繼續執行。而斷言是完全無法忽略的,程序在斷言失敗處立即終止。因此斷言通常用于調試版本,用來發現程序中的邏輯錯誤。雖然異常也能起到這樣的作用,但是不應該用異常代替斷言:
1) 如果發現了邏輯錯誤,必須修改程序,而不可能在程序中進行處理和恢復,所以不需要向外傳送,沒有必要使用異常。
2) 使用斷言的開銷比異常小得多,而且斷言可以從發布版中完全去除。
?
異常用于處理正確程序中的運行期問題(比如內存分配失敗,窗口創建失敗,線程創建失敗,打開文件失敗),以盡可能恢復,而不是終止程序。對于運行異常,使用斷言是非常不合適的,理由很顯然:
1) 斷言在發布版不起作用;
2) 斷言的處理方式不夠友好;
3) 運行異常不是程序錯誤,沒有必要報告源代碼出錯位置;
參考資料:
1.《C++編程規范-101條規則、準則與最佳實踐》/Herb Sutter,Andrei Alexandrescu 著 劉基誠 譯 人民郵電出版社
2.《C++程序設計語言》/Bjarne Stroustrup 著?裘宗燕 譯 機械工業出版社
3.《C與C++中的異常處理》/Robert Schmidt 著 無情 譯 http://download.pchome.net/development/reference/11135.html