C++_异常6-其他异常特性
雖然throw-catch機制類似于函數參數和函數返回機制,但是還是有些不同之處。
其中之一是函數fun()中的返回語句將控制權返回到調用fun()的函數A中,
但throw語句將控制權向上返回到第一個這樣的函數:包含能夠捕獲相應異常的try-catch組合。
?
另一個不同之處是,引發異常時,編譯器總是創建一個臨時拷貝,即使異常規范和catch塊中指定的是引用。
請看下列代碼
class problem {...}
...
void super() throw(problem)
{
? ? ...
? ?if(oh_no)
? ?{
? ? ? ? problem oops;? ?//construct object
? ? ? ? throw opps;? ? ? ?//throw it
? ? ...
}
...
?
tyr{
? ? super();
}
catch(problem & p)
{
//statements
}
?
此時p將指向oops的副本而不是oops本身。這是件好事,因為super()執行完畢后,oops將不復存在。
另外:將引發異常和創建對象組合在一起會更加簡單
throw problem();?
?
將引用作為返回值的通常原因是避免創建副本以提高效率。那么既然throw語句將生成副本,為何代碼中使用引用呢?
答案是,引用還有另外一個重要特征:基類引用可以執行派生類對象。
假設有一組通過繼承關聯起來的異常類型,則在異常規范中只需列出一個基類引用,它將與任何派生類對象匹配。
?
假設有一個異常類層次結構,并要分別處理不同的異常類型,則使用基類引用將能夠捕獲任何異常對象。
而使用派生類對象只能捕獲它所屬類及從這個類派生而來的類的對象。
引發異常對象將被第一個與之匹配的catch塊捕獲。這意味著catch塊的排列順序應該與派生順序相反。
?
class bad_1 {...};
class bad_2 : public bad_1 {...};
class bad_3 : public bad_2 {...};
...
void duper()
{
? ? ...
? ? if(oh_no)
? ? ? ? throw bad_1()
? ? if(rats)
? ? ? ? throw bad_2()
? ? if(drat)
? ? ? ? throw bad_3()
}
...
try{
? ? duper();
}
catch(bad_3 &be)
{// statements }
catch(bad_2 &be)
{// statements }
catch(bad_1 &be)
{// statements }
如果將bad_3放在最前面,它將捕獲bad_1、bad_2和bad_3;
通過按照相反的順序排列,bad_3異常將被bad_3 &處理程序所捕獲。
通過正確地安排catch塊的順序,讓您能夠在如何處理異常方面有選擇的余地。
?
有時候可能不知道會發生哪些異常,在這種情況下,仍能捕獲異常,即使不知道異常的類型。
方法是使用省略號來表示異常類型,從而捕獲任何異常:
catch { ... }
可以將這個放在最后,有點像switch中的default。
?
轉載于:https://www.cnblogs.com/grooovvve/p/10435117.html
總結
以上是生活随笔為你收集整理的C++_异常6-其他异常特性的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 进程与多并发
- 下一篇: 在c++中使用for循环遍历map并删除