C 四種強制型別轉換詳解

2021-06-18 01:17:49 字數 2967 閱讀 9865

型別轉換的含義是通過改變乙個變數的型別為別的型別從而改變該變數的表示方式。為了型別轉換乙個簡單物件為另乙個物件你會使用傳統的型別轉換操作符。

//c中:

//複製** **如下:

(t)element 或者 t(element)

//c++中:

//複製** **如下:

reinterpret_cast(expression)

dynamic_cast(expression)

static_cast(expression)

const_cast(expression)

dynamic_cast 主要用於執行「安全的向下轉型(safe downcasting)」,也就是說,要確定乙個物件是否是乙個繼承體系中的乙個特定型別。它是唯一不能用舊風格語法執行的強制轉型,也是唯一可能有重大執行時代價的強制轉型。

static_cast 可以被用於強制隱型轉換(例如,non-const 物件轉型為 const 物件,int 轉型為 double,等等),它還可以用於很多這樣的轉換的反向轉換(例如,void* 指標轉型為有型別指標,基類指標轉型為派生類指標),但是它不能將乙個 const 物件轉型為 non-const 物件(只有 const_cast 能做到),它最接近於c-style的轉換

const_cast 一般用於強制消除物件的常量性。它是唯一能做到這一點的 c++ 風格的強制轉型。

reinterpret_cast 是特意用於底層的強制轉型,導致實現依賴(implementation-dependent)(就是說,不可移植)的結果,例如,將乙個指標轉型為乙個整數。這樣的強制轉型在底層**以外應該極為罕見。

dynamic_cast                  // 通常在基類和派生類之間轉換時使用

static_cast                       // 一般的轉換,如果你不知道該用哪個,就用這

const_cast                      // 主要針對const和volatile的轉換

reinterpret_cast              // 用於進行沒有任何關聯之間的轉換,比如乙個字元指標轉換為乙個整形數

1)static_cast(a) 編譯器在編譯期處理

將位址a轉換成型別t,t和a必須是指標、引用、算術型別或列舉型別。

表示式static_cast(a), a的值轉換為模板中指定的型別t。 

在執行時轉換過程中,不進行型別檢查來確保轉換的安全性。

static_cast它能在內建的資料型別間互相轉換,對於類只能在有聯絡的指標型別間進行轉換。可以在繼承體系中把指標轉換來、轉換去,但是不能轉換成繼承體系外的一種型別

複製** **如下:

class a ;

class b ;

class d : public b ;

void f(b* pb, d* pd)

2)dynamic_cast(a) 在執行期,會檢查這個轉換是否可能

完成類層次結構中的提公升。t必須是乙個指標、引用或無型別的指標。a必須是決定乙個指標或引用的表示式。 

dynamic_cast 僅能應用於指標或者引用,不支援內建資料型別

表示式dynamic_cast(a) 將a值轉換為型別為t的物件指標。如果型別t不是a的某個基型別,該操作將返回乙個空指標。 

它不僅僅像static_cast那樣,檢查轉換前後的兩個指標是否屬於同乙個繼承樹,它還要檢查被指標引用的物件的實際型別,確定轉換是否可行。

如果可以,它返回乙個新指標,甚至計算出為處理多繼承的需要的必要的偏移量。如果這兩個指標間不能轉換,轉換就會失敗,此時返回空指標(null)。 

很明顯,為了讓dynamic_cast能正常工作,必須讓編譯器支援執行期型別資訊(rtti)。

複製** **如下:

class base  };

class derived : public base {};

base* b1 = new derived;

base* b2 = new base;

derived* d1 = dynamic_cast(b1); // succeeds

derived* d2 = dynamic_cast(b2); // fails: returns 'null'

3)const_cast(a)編譯器在編譯期處理

去掉型別中的常量,除了const或不穩定的變址數,t和a必須是相同的型別。 

表示式const_cast(a)被用於從乙個類中去除以下這些屬性:const, volatile, 和 __unaligned。

對於本身定義時為const的型別,即使你去掉const性,在你操作這片內容時候也要小心,只能r不能w操作,否則還是會出錯 

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

複製** **如下:

class a ;

void f()

const char* p = "123";

char* c = const_cast(p);

c[0] = 1; //表面上通過編譯去掉了const性,但是操作其位址時系統依然不允許這麼做。

4)reinterpret_cast(a)編譯器在編譯期處理

任何指標都可以轉換成其它型別的指標,t必須是乙個指標、引用、算術型別、指向函式的指標或指向乙個類成員的指標。 

表示式reinterpret_cast(a)能夠用於諸如char* 到 int*,或者one_class* 到 unrelated_class*等類似這樣的轉換,因此可能是不安全的。

複製** **如下:

class a ;

class b ;

void f()

詳細出處參考:

C 四種強制型別轉換

c風格的強制型別轉換 type cast 很簡單,不管什麼型別的轉換統統是 type b type a c 風格的型別轉換提供了4種型別轉換操作符來應對不同場合的應用。const cast,字面上理解就是去const屬性。static cast,命名上理解是靜態型別轉換。如int轉換成char。dy...

C 四種強制型別轉換

1 概述 去const屬性用const cast。基本型別轉換用static cast。多型類之間的型別轉換用daynamic cast。不同型別的指標型別轉換用reinterpreter cast。2 詳解加示例 a const cast 用法 const cast 型別 表示式 用途 刪除con...

C 四種強制型別轉換

c風格的強制型別轉換 type cast 很簡單,不管什麼型別的轉換統統是 type b type a c 風格的型別轉換提供了4種型別轉換操作符來應對不同場合的應用。const cast,字面上理解就是去const屬性。static cast,命名上理解是靜態型別轉換。如int轉換成char。dy...