C 向上型別轉換和向下型別轉換

2021-09-30 11:07:56 字數 1321 閱讀 2271

有乙個毛病:遇到乙個問題,總想著以後在遇到再解決,導致乙個簡單的餓問題永遠在拖延,什麼也沒弄會。不知怎麼養成這個壞習慣,誓改之。

一、向上型別轉換:

所謂向上型別轉換,是指取乙個物件的位址,將其作為基類的位址處理,因為繼承樹是以基類為頂點的。

此種轉換無需顯式型別轉換,正是利用這一性質從而實現了多型性。

二、向下型別轉換

即按繼承樹向下轉換,轉換時會有多種選擇,需顯式型別轉換dynamic_cast

引出另乙個問題,型別轉換的方式與區別,參考部落格

1.c型別的強制型別轉換

很簡單,不需多言

2.static_cast可以實現c++中內建基本資料型別之間的相互轉換。

int c=static_cast(7.987);
如果涉及到類的話,static_cast只能在有相互聯絡的型別中進行相互轉換,不一定包含虛函式。

3.const_cast: const_cast操作不能在不同的種類間轉換。相反,它僅僅把乙個它作用的表示式轉換成常量。它可以使乙個本來不是const型別的資料轉換成const型別的,或者把const屬性去掉。

4.reinterpret_cast: 有著和c風格的強制轉換同樣的能力。它可以轉化任何內建的資料型別為其他任何的資料型別,也可以轉化任何指標型別為其他的型別。它甚至可以轉化內建的資料型別為指標,無須考慮型別安全或者常量的情形。不到萬不得已絕對不用。

5.dynamic_cast:

(1)其他三種都是編譯時完成的,dynamic_cast是執行時處理的,執行時要進行型別檢查。

(2)不能用於內建的基本資料型別的強制轉換。

(3)dynamic_cast轉換如果成功的話返回的是指向類的指標或引用,轉換失敗的話則會返回null。

(4)使用dynamic_cast進行轉換的,基類中一定要有虛函式,否則編譯不通過。

b中需要檢測有虛函式的原因:類中存在虛函式,就說明它有想要讓基類指標或引用指向派生類物件的情況,此時轉換才有意義。

這是由於執行時型別檢查需要執行時型別資訊,而這個資訊儲存在類的虛函式表(關於虛函式表的概念,詳細可見)中,

只有定義了虛函式的類才有虛函式表。

(5)在類的轉換時,在類層次間進行上行轉換時,dynamic_cast和static_cast的效果是一樣的。在進行下行轉換時,dynamic_cast具有型別檢查的功能,比               static_cast更安全。向上轉換即為指向子類物件的向下轉換,即將父類指標轉化子類指標。向下轉換的成功與否還與將要轉換的型別有關,即要轉換的指標指向的物件的實際型別與轉換以後的物件型別一定要相同,否則轉換失敗。



向上型別轉換和向下型別轉換

向上轉型 student person new student 1 將乙個父類的引用指向乙個子類物件,成為向上轉型,自動進行型別轉換。2 此時通過父類引用變數呼叫的方法是子類覆蓋或繼承父類的方法,而不是父類的方法 3 此時通過父類引用變數無法呼叫子類特有的方法 向下轉型 student stu st...

c 中向上型別轉換和向下型別轉換

在c 的世界中有這樣兩個概念,向上型別轉換,向下型別轉換,分別描述的是子類向基類和基類向子類的強制型別轉換。在向上型別轉換的過程中 使用指標和引用不會造成切割,而使用直接賦值會造成切割。在向下型別轉換的過程中 使用dynamic cast進行向下強制型別轉換。使用此關鍵字有一下幾個條件 必須有虛函式...

C 中的向上型別轉換和向下型別轉換

在c 的世界中有這樣兩個概念,向上型別轉換,向下型別轉換,分別描述的是子類向基類,和基類向子類的強制型別轉換。向上強制型別轉換 切割 覆蓋方法和子類資料丟失的現象生成切割 slice cpp view plain copy class base class derived public base i...