C 型別轉化

2021-07-14 20:16:29 字數 1338 閱讀 7057

c++型別轉化

在理解c++型別轉換前,我們先回顧c語言中型別轉換。c風格的強制型別轉化很簡單,不管什麼型別轉換統統是

type b=(type)a。

但是c風格的型別轉換有不少的缺點,有的時候用c風格的轉換是不合適的,因為它可以在任意型別之間轉換,比如你可以把乙個指向const物件的指標轉換成指向非const物件的指標,把乙個指向基類物件的指標轉換成指向乙個派生類物件的指標,這兩種轉換之間的差別是巨大的,但是傳統的c語言風格的型別轉換沒有區分這些。還有乙個缺點就是,c風格的轉換不容易查詢,他由乙個括號加上乙個識別符號組成,而這樣的東西在c++程式裡一大堆。

所以c++為了克服這些缺點,引進了4新的型別轉換操作符,他們是1.static_cast  2.const_cast  3.dynamic_cast  4.reinterpret_cast.

1.static_cast

靜態型別轉換,編譯時c++編譯器會做型別檢查,這也是最常用的型別轉換符,在正常狀況下的型別轉換,如把int轉換為float,如:int i;float f; f=(float)i;或者f=static_cast(i);

2.const_cast

用於取出const屬性,把const型別的指標變為非const型別的指標(去除變數的唯讀屬性),

如:const int *fun(int x,int y){}  int *ptr=const_cast(fun(2.3))

3.dynamic_cast

該操作符用於執行時檢查該轉換是否型別安全(稱為

動態型別轉換,用於安全的基類和子類之間轉換;執行時型別檢查

),但只在多型型別時合法,即該類至少具有乙個虛擬方法。dynamic_cast與static_cast具有相同的基本語法,dynamic_cast主要用於類層次間的上行轉換和下行轉換,還可以用於類之間的交叉轉換。在類層次間進行上行轉換時,dynamic_cast和static_cast的效果是一樣的;在進行下行轉換時,dynamic_cast具有型別檢查的功能,比static_cast更安全。如:

class c ;

class t

int main()

此時如改為以下則是合法的:

class c

;// c現在是 多型}

4.reinterpret_cast

interpret是解釋的意思,reinterpret即為重新解釋,此識別符號的意思即為資料的二進位制形式重新解釋,但是不改變其值。如:int i; char *ptr="hello freind!"; i=reinterpret_cast(ptr);這個轉換方式很少使用。

c 型別轉化

資料型別轉換 隱式轉換 int age 10 double sum age int salary 150000 decimal money salary double speed 10.4f float minspeed float speed string num 123 int n int.pa...

C 型別轉化

const char a 必須const 因為 hello 存在常量區,為唯讀 string str hello str 1 s pass a str.c str a 1 s fail 報錯 唯讀,指標指向常量區char a a 11 int b atoi a cout string str to ...

C 型別轉化

在 c 中,int int32.parse 和 convert.toint32 三種方法有何區別?int 關鍵字表示一種整型,是32位的,它的 net framework 型別為 system.int32。int 表示使用顯式強制轉換,是一種型別轉換。當我們從 int 型別到 long float ...