c風格的強制型別轉換(type case)很簡單,不管什麼型別的傳統轉換都是:type b = (type)a,但是c風格的型別轉換有不少的缺點,有的時候用c風格的轉換是不合適的,因為它可以在任意型別之間進行轉換,比如你可以把乙個指向const型別的指標轉換成指向非const型別的指標,把乙個指向基類物件的指標指向派生類物件的指標,這兩者之間的轉換差距是巨大的,但是傳統的c風格的轉換沒有區分這些。還有乙個缺陷,c風格的轉換不容易查詢,它有乙個括號和乙個識別符號組成,而這樣的東西在c++程式中一大堆。所以c++為了克服這些缺陷,引進了四種型別轉換操作符。
1、static_cast
功能:完成編譯器認可的隱式型別轉換
格式:
type1 a;
type2 b = static_cast(a); //將type1型別轉換成type2型別
使用範圍:
(1) 基本資料型別之間的轉換,如int->double
int a = 6;
folat b = static_cast(a);
(2) 基類和派生類之間的轉換,但只能用於類的指標或者引用之間的轉換
class base{};
class derived:public base{};
base *b;
derived *d = new derived();
b = static_cast(d)
2、dynamic_cast
功能:基類和派生類之間的轉換,但只能用於類的指標或者引用之間的轉換
格式:
(1) 其他三種都是編譯時完成的,dynamic_cast是執行時處理的,執行時需要進行型別檢查;
(2) 基類中要有虛函式,因為型別檢查的型別資訊在虛函式表中,有虛函式才會有虛函式表;
(3) 可以實現向上轉型和向下轉型,前提必須使用public或protected繼承;
例子:
class base
class derived:public base
base *b;
derived *d = new derived();
b = static_cast(d)
3、const_cast
功能:只能對指標或引用去除或者新增const屬性,只能改變同種型別的const屬性
常用用法:
(1) 常用於函式的形參是乙個非const的引用,我想要傳進去乙個const的引用,可以使用const_cast去除引數的常亮性,以便函式能夠接受這個引數;
(2) 乙個const物件,我們想要呼叫該物件中的非const函式,可以使用const_cast去除物件的常亮性;
4、reinterpret_cast
從字面意思就是「重新解釋的型別轉換」。也就是說任意兩個型別之間都可以使用使用reinterpret_cast進行型別轉換。
C 四種型別轉換方式
reinterpert cast意圖執行低階轉換,實際動作 及結果 可能取決於編譯器,這也就表示它不可移植。例如將乙個 pointer to int 轉型為乙個 int 這一型別在底層 以外很少見。示例 class a class b a a new a b b reinterpret a rein...
C 四種型別轉換方式
static cast 靜態型別轉換。reinterpreter cast 重新解釋型別轉換。dynamic cast 子類和父類之間的多型型別轉換。const cast 去掉const屬性轉換 這應該四種中是最常見的。用法為 static cast expression 該運算子把 express...
C 中四種型別轉換方式
型別轉換有c風格的,當然還有c 風格的。c風格的轉換的格式很簡單 type expression,但是c風格的型別轉換有不少的缺點,有的時候用c風格的轉換是不合適的,因為它可以在任意型別之間轉換,比如你可以把乙個指向const物件的指標轉換成指向非const物件的指標,把乙個指向基類物件的指標轉換成...