C++常見異常處理原理及代碼示例解析
編程中常見的錯誤
- 程序的編譯錯誤——比較好解決,主要是一些語法錯誤
- 程序的運行錯誤——產生因素較為復雜,如空間不夠,下標越界,訪問非法空間等。
異常是指程序運行時出現(xiàn)的不正常,可分為一下幾類:
CPU異常;如在計算過程中,出現(xiàn)除數(shù)為0的情況。
內存異常,如:
- 使用new或malloc申請動態(tài)內存但存儲空間不夠;
- 數(shù)組下標越界;
- 使用野指針、迷途指針讀取內存;
設備異常,如:
- 無法打開文件,或文件損壞;
- 正在讀取磁盤文件時挪動了文件或磁盤;
- 正在使用打印機但設備被斷開;
- 正在使用的網(wǎng)絡斷線或阻塞;
用戶數(shù)據(jù)異常,如:
- scanf輸入數(shù)據(jù)格式或類型有錯誤;
- 正在處理的數(shù)據(jù)庫有錯誤;
- 程序假定的數(shù)據(jù)環(huán)境發(fā)生變化;
- 異常處理機制
拋出異常(throw)、檢查異常(try塊)、捕獲異常(catch塊)
C++是根據(jù)類型區(qū)分不同異常的,因此在拋出異常時,throw表達式的值沒有實際意義,而表達式的類型則非常重要;如果程序中有多處要拋出的異常,應該用不同的表達式類型來相互區(qū)別。
關于throw的說明
- 執(zhí)行throw的時候,不會執(zhí)行跟在throw后面的語句,而是將程序從throw轉移到匹配的catch,該catch可以是同一函數(shù)中的catch,也可以在直接或間接調用發(fā)生異常函數(shù)的上一級函數(shù)中。
- 被拋出的對象是一個用throw表達式初始化的「異常對象」,異常對象由throw創(chuàng)建,并初始化為被拋出的表達式副本,異常對象將傳遞給對應的catch,并在異常處理完成后撤銷。因此異常對象必須是可以復制的類型(具有復制構造函數(shù))。
- 如果拋出的是數(shù)組,被拋出的對象自動轉換為指向該數(shù)組首元素的指針,如果拋出的是一個函數(shù),函數(shù)被轉換為指向該函數(shù)的指針。
- 如果拋出一個指向派生類對象的基類指針,則其對象將被分割,只拋出基類的部分。
- 拋出指向局部對象的指針總是錯誤的,因為拋出指針的時候,必須確保進入異常處理程序時,指針所指向的對象仍然存在。
檢測捕獲異常
一般形式:
try{
....//檢測程序塊(可能拋出異常的代碼)
}
catch(異常說明符1){
....//處理程序(當異常說明符1被拋出時執(zhí)行的程序)
}
catch(異常說明符2){
....//處理程序(當異常說明符2被拋出時執(zhí)行的程序)
}
..... //更多的catch
catch子句的形參列表
catch(類型名) //catch只需要了解異常的類型
catch(類型名 形參名) //catch需要了解異常類型之外的信息
catch(...) //捕獲所有異常
重拋異常
在catch子句中,可以再次拋出異常,其中throw不加表達式,表示將捕獲到的異常再次向上級函數(shù)拋出,不會被本函數(shù)的其他catch子句捕獲。
try{
throw "hello"; //拋出char* 異常
}
catch(const char*){ //捕獲char*異常
throw; //重新拋出char* 異常至上一級函數(shù)
}
throw關鍵字修飾的函數(shù)
C++函數(shù)后面加關鍵字throw(something)限制,是對這個函數(shù)的異常安全作出限制;這是一種異常規(guī)范,只會出現(xiàn)在聲明函數(shù)時,表示這個函數(shù)可能拋出的異常類型。
void fun() throw(); //表示fun函數(shù)不允許拋出任何異常,即fun函數(shù)是異常安全的
void fun() throw(...); //表示fun函數(shù)可以拋出任何形式的異常
void fun() throw(exceptionType) //表示fun函數(shù)只能拋出exceptionType類型的異常
如void GetTag() throw(int);表示只能拋出int類型的異常,如果拋出非int類型的異常,則會調用unexsetpion()函數(shù),退出程序。假如在函數(shù)聲明時用throw()限定(這個函數(shù)本身不可能拋出異常),則編譯器在決定其優(yōu)化方式上更加靈活。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
Sersync+Rsync實現(xiàn)觸發(fā)式文件同步實戰(zhàn)過程
sersync是使用c++編寫,而且對linux系統(tǒng)文 件系統(tǒng)產生的臨時文件和重復的文件操作進行過濾。下面通過本文給大家分享Sersync+Rsync實現(xiàn)觸發(fā)式文件同步實戰(zhàn)過程,需要的朋友參考下吧2017-09-09
VS2019配置opencv詳細圖文教程和測試代碼的實現(xiàn)
這篇文章主要介紹了VS2019配置opencv詳細圖文教程和測試代碼的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-04-04

