型別轉換有c風格的,當然還有c++風格的。c風格的轉換的格式很簡單 (type)expression,但是c風格的型別轉換有不少的缺點,有的時候用c風格的轉換是不合適的,因為它可以在任意型別之間轉換,比如你可以把乙個指向const物件的指標轉換成指向非const物件的指標,把乙個指向基類物件的指標轉換成指向乙個派生類物件的指標,這兩種轉換之間的差別是巨大的,但是傳統的c語言風格的型別轉換沒有區分這些。還有乙個缺點就是,c風格的轉換不容易查詢,他由乙個括號加上乙個識別符號組成,而這樣的東西在c++程式裡一大堆。所以c++為了克服這些缺點,引進了4新的型別轉換操作符,他們是:static_cast const_cast dynamic_cast reinterpret_cast.
最常用的型別轉換符,在正常狀況下的型別轉換,如把int轉換為float,如:
int i;
float f;
f = (float)i; 或者 f = static_cast(i);
用於取出const屬性,把const型別的指標變為非const型別的指標,如:
const int *fun(int x, int y)
int *ptr = const_cast(fun(2, 3));
該操作符用於執行時檢查該轉換是否型別安全,但只在多型型別時合法,即該類至少具有乙個虛擬方法。dynamic_cast與static_cast具有相同的基本語法,dynamic_cast主要用於類層次間的上行轉換和下行轉換,還可以用於類之間的交叉轉換。在類層次間進行上行轉換時,dynamic_cast和static_cast的效果是一樣的;在進行下行轉換時,dynamic_cast具有型別檢查的功能,比static_cast更安全。如:
class c
;class t
int main()
//此時如改為以下則是合法的:
class c
; // c現在是 多型
}
interpret是解釋的意思,reinterpret即為重新解釋,此識別符號的意思即為資料的二進位制形式重新解釋,但是不改變其值。如:
int i;
char *ptr="hello freind!";
i = reinterpret_cast(ptr); //只是對指標變數ptr的值進行重新解釋
這個轉換方式很少使用。
如果編寫乙個標準strcpy函式的總分值為10,下面給出幾個不同得分的答案:
2分
void strcpy( char *strdest, char *strsrc )
4分void strcpy( char *strdest, const char *strsrc )
//將源字串加const,表明其為輸入引數,加2分
7分void strcpy(char *strdest, const char *strsrc)
10分//為了實現鏈式操作,將目的位址返回,加3分!
char * strcpy( char *strdest, const char *strsrc )
從2分到10分的幾個答案我們可以清楚的看到,小小的strcpy竟然暗藏著這麼多玄機,真不是蓋的!
需要多麼紮實的基本功才能寫乙個完美的strcpy啊!
讀者看了不同分值的strcpy版本,應該也可以寫出乙個10分的strlen函式了,完美的版本為:
int strlen( const char *str ) //輸入引數const
return len;
}
c 中四種型別轉換
2.型別轉換 c 中的型別轉換 四種型別裝換符 static cast 基礎資料型別的轉換和繼承中父類與子類,指標與引用裝換 dynamic cast 通常在基類和派生類之間轉換時使用 const cast 主要針對const的轉換 reinterpret cast 用於進行沒有任何關聯之間的轉換,...
c 中的四種型別轉換的區別
型別轉換有c風格的,當然還有c 風格的。c風格的轉換的格式很簡單 type expression 但是c風格的型別轉換有不少的缺點,有的時候用c風格的轉換是不合適的,因為它可以在任意型別之間轉換,比如你可以把乙個指向const物件的指標轉換 成指向非const物件的指標,把乙個指向基類物件的指標轉換...
c 中的四種型別轉換的區別
型別轉換有c風格的,當然還有c 風格的。c風格的轉換的格式很簡單 type expression 但是c風格的型別轉換有不少的缺點,有的時候用c風格的轉換是不合適的,因為它可以在任意型別之間轉換,比如你可以把乙個指向const物件的指標轉換 成指向非const物件的指標,把乙個指向基類物件的指標轉換...