c 的四種強制轉換型別

2021-08-09 21:24:03 字數 1757 閱讀 8242

內容來自:

編譯器在編譯期處理

將位址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)  

在執行期,會檢查這個轉換是否可能

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

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

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

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

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

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

編譯器在編譯期處理

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

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

class a ;  

void f()    

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

const

char* p = "123";   

char* c = const_cast

(p);   

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

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

盡量不要使用const_cast,如果發現呼叫自己的函式,竟然使用了const_cast,那就趕緊打住,重新考慮一下設計吧。

編譯器在編譯期處理

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

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

class a ;  

class b ;  

void f()    

使用reinterpret_cast 的場合不多,僅在非常必要的情形下,其他型別的強制轉換不能滿足要求時才使用。

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...