c語言使用強制型別轉換(type cast)很簡單,不管什麼型別的轉換,形式都如下:
type b = (type)a;
c++提供了4種型別轉換操作符來應對不同場合的應用。
const_cast static_cast dynamic_cast reinterpreter_cast
4種關鍵字的使用形式如下:
type b = static_cast(type)(a)
1.const_cast 去掉型別的const或volatile屬性
const sa ra = ;
= 5;
sa &rb =const_cast (ra);
rb.i = 134;
****關鍵點:這個地方引出了乙個問題?
常量值能否進行更改???
我們通過上述**知道,當rb.i = 134時,ra.i的值也進行了更改
所以常量的值是可以進行更改的,原因就是 使用了const_cast及引用型別
2、static_cast
類似於c風格的強制轉換。無條件轉換,靜態型別轉換。用於:
1. 基類和子類之間轉換:其中子類指標轉換成父類指標是安全的;但父類指標轉換成子類指標是不安全的。(基類和子類之間的動態型別轉換建議用dynamic_cast)
2. 基本資料型別轉換。enum, struct, int, char, float等。static_cast不能進行無關型別(如非基類和子類)指標之間的轉換。
3. 把空指標轉換成目標型別的空指標。
4. 把任何型別的表示式轉換成void型別。
5. static_cast不能去掉型別的const、volitale屬性(用const_cast)。
int n = 6;
double d = static_castdouble>(n); // 基本型別轉換
int *pn = &n;
double *d = static_castdouble *>(&n) //無關型別指標轉換,編譯錯誤
void *p = static_castvoid *>(pn); //任意型別轉換成void型別
reinterpreter_cast
僅僅重新解釋型別,但沒有進行二進位制的轉換:
1. 轉換的型別必須是乙個指標、引用、算術型別、函式指標或者成員指標。
2. 在位元位級別上進行轉換。它可以把乙個指標轉換成乙個整數,也可以把乙個整數轉換成乙個指標(先把乙個指標轉換成乙個整數,在把該整數轉換成原型別的指標,還可以得到原先的指標值)。但不能將非32bit的例項轉成指標。
3. 最普通的用途就是在函式指標型別之間進行轉換。
4. 很難保證移植性。
int dosomething();
typedef void(*funcptr)();
//funcptr is 乙個指向函式的指標,該函式沒有引數,返回值型別為 void
funcptr funcptrarray[10];
//10個funcptrs指標的陣列 讓我們假設你希望(因為某些莫名其妙的原因)把乙個指向下面函式的指標存入funcptrarray陣列:
funcptrarray[0] = &dosomething;
// 編譯錯誤!型別不匹配,reinterpret_cast可以讓編譯器以你的方法去看待它們:funcptrarray
funcptrarray[0] = reinterpret_castfuncptr>(&dosomething);
//不同函式指標型別之間進行轉換
總 結去const屬性用const_cast。
基本型別轉換用static_cast。
多型類之間的型別轉換用daynamic_cast。
不同型別的指標型別轉換用reinterpreter_cast。
C 四種強制型別轉換關鍵字
型別轉換有c風格的,當然還有c 風格的。c風格的轉換的格式很簡單 type expression,但是c風格的型別轉換有不少的缺點,有的時候用c風格的轉換是不合適的,因為它可以在任意型別之間轉換,比如你可以把乙個指向const物件的指標轉換成指向非const物件的指標,把乙個指向基類物件的指標轉換成...
c 中的四種強制型別轉換關鍵字
1 reinterpret cast reinterpret cast type id expression reinterpret cast轉換乙個指標為其它型別的指標。它也允許從乙個指標轉換為整數型別。反之亦然。這個操作符能夠在非相關的型別之間轉換。操作結果只是簡單的從乙個指標到別的指標的值的二...
C 轉換關鍵字
implicit為隱式的轉換 explicit為顯示的轉換 通過這種方法可以有效地驗證資料,對引數進行處理。不管是否實用,在此先記錄下來 以後回顧用 class 轉換關鍵字 set public myage private myage int32 age 整型到myage 的隱式轉換 public ...