先看一段代碼: 運行結果如下,情理之中,意料之內: C++創建對象的時候先創建基類部分,然后創建派生部分。析構的時候要反過來了,先釋放子類部分,然后在釋放父類部分。但是這里只釋放了父類部分,沒有釋放派生類的部分。為什么呢? 原因很明確:因為之類pB是基類指針,雖然指向 ...
沒有指定虛函數,那么它就只能訪問到類型對應的函數基類指針就只能訪問到基類函數子類指針就只能訪問到子類函數要使用基類訪問到子類的函數,最符合常規的,就是虛函數了. 當然,你也可以使用非常規的,比如強制轉換,比如自己計算函數地址並調用. 正常情況,子類祖先類的析構函數都是虛擬的,這樣刪除祖先類指針 子類對象的時候,可正確同時調用子類和祖先類的析構函數 : 看一下幾個結論: ,如果以一個基礎類指針指向一 ...
2019-09-15 14:32 0 486 推薦指數:
先看一段代碼: 運行結果如下,情理之中,意料之內: C++創建對象的時候先創建基類部分,然后創建派生部分。析構的時候要反過來了,先釋放子類部分,然后在釋放父類部分。但是這里只釋放了父類部分,沒有釋放派生類的部分。為什么呢? 原因很明確:因為之類pB是基類指針,雖然指向 ...
派生類對象也“是”基類對象,但兩者不同。 派生類對象可以當做基類對象,這是因為派生類包含基類的所有成員。 但是基類對象無法被當做成派生類對象,因為派生類可能具有只有派生類才有的成員。 所以,將派生類指針指向基類對象的時候要進行顯示的強制轉換,否則會使基類對象中的派生類成員成為未定義 ...
我們在程序中定義了一個基類,該基類有n個子類,為了方便,我們經常定義一個基類的指針數組,數組中的每一項指向都指向一個子類,那么在程序中我們如何判斷這些基類指針是指向哪個子類呢? 本文提供了兩種方法 (1) 自定義類id, (2)typeid 一、自定義id 如下所示基類father有兩個子類 ...
我們在程序中定義了一個基類,該基類有n個子類,為了方便,我們經常定義一個基類的指針數組,數組中的每一項指向都指向一個子類,那么在程序中我們如何判斷這些基類指針是指向哪個子類呢? 本文提供了兩種方法 (1) 自定義類id, (2)typeid 一、自定義id 如下所示基類father有兩個子類 ...
靜態綁定 如果以一個基礎類指針指向一個衍生類對象(派生類對象),那么經由該指針只能訪問基礎類定義的函數 如果以一個衍生類指針指向一個基礎類對象,必須先做強制轉型動作(explicit cast),這種做法很危險,也不符合生活習慣,在程序設計上也會給程序員帶來困擾。 如果基礎類和衍生 ...
父類子類指針函數調用注意事項1,如果以一個基礎類指針指向一個衍生類對象(派生類對象),那么經由該指針只能訪問基礎類定義的函數(靜態聯翩)2,如果以一個衍生類指針指向一個基礎類對象,必須先做強制轉型動作(explicit cast),這種做法很危險,也不符合生活習慣,在程序設計上也會給程序員帶來困擾 ...
c++父類指針指向子類對象 父類子類指針函數調用注意事項1,如果以一個基礎類指針指向一個衍生類對象(派生類對象),那么經由該指針只能訪問基礎類定義的函數(靜態聯翩)2,如果以一個衍生類指針指向一個基礎類對象,必須先做強制轉型動作(explicit cast),這種做法 ...