您好,登錄后才能下訂單哦!
C++中怎么保證析構函數不拋出異常,相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。
所有的析構函數都可以不失敗。如果析構函數試圖拋出異常退出,這是嚴重的設計錯誤,更好的選擇是中止程序。
A destructor (either user-defined or compiler-generated) is implicitly declared noexcept (independently of what code is in its body) if all of the members of its class have noexcept destructors. By explicitly marking destructors noexcept, an author guards against the destructor becoming implicitly noexcept(false) through the addition or modification of a class member.
如果類的所有的成員的析構函數都是noexcept的,它的析構函數(無論是用戶定義的還是編譯器生成的)就會被隱式定義為noexcept(這和函數體內的具體代碼無關)。通過顯式定義析構函數為noexcept,可以防止析構函數由于類成員被修改而無法成為noexcpet。
Not all destructors are noexcept by default; one throwing member poisons the whole class hierarchy
不是所有的析構函數都默認是noexcept的;只要有一個(析構時,譯者注)拋出異常的成員,就會破壞整個繼承體系。
struct X {
Details x; // happens to have a throwing destructor
// ...
~X() { } // implicitly noexcept(false); aka can throw
};
左右滑動查看更多
So, if in doubt, declare a destructor noexcept.
因此,如果有疑問,就將析構函數定義為noexcept。
Why not then declare all destructors noexcept? Because that would in many cases -- especially simple cases -- be distracting clutter.
為什么不將所有的析構函數都定義為noexcept?因為在很多場合,特別是簡單的場合這樣做只會增加干擾信息。
(Simple) A destructor should be declarednoexcept
if it could throw.
(簡單)如果存在拋出異常的風險,則將析構函數定義為noexcept。
看完上述內容,你們掌握C++中怎么保證析構函數不拋出異常的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。