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