型別轉換有c風格的,當然還有c++風格的。c風格的轉換的格式很簡單
(type)expression,
但是c風格的型別轉換有不少的缺
點,有的時候用c風格的轉換是不合適的,因為它可以在任意型別之間轉換,比如你可以把乙個指向const物件的指標轉換成指向非
const物件的指標,把乙個指向基類物件的指標轉換成指向乙個派生類物件的指標,這兩種轉換之間的差別是巨大的,但是傳統的c
語言風格的型別轉換沒有區分這些。還有乙個缺點就是,c風格的轉換不容易查詢,他由乙個括號加上乙個識別符號組成,而這樣的東
西在c++程式裡一大堆。
所以c++為了克服這些缺點,引進了4新的型別轉換操作符,他們是1.static_cast 2.const_cast
3.dynamic_cast 4.reinterpret_cast.
1.static_cast
最常用的型別轉換符,在正常狀況下的型別轉換,如把int轉換為float,如:int i;float f; f=(float)i;或者
f=static_cast(i);
用法:static_cast < type-id > ( expression )
該運算子把expression轉換為type-id型別,但沒有執行時型別檢查來保證轉換的安全性。它主要有如下幾種用法:
①用於類層次結構中基類和子類之間指標或引用的轉換。
進行上行轉換(把子類的指標或引用轉換成基類表示)是安全的;
進行下行轉換(把基類指標或引用轉換成子類表示)時,由於沒有動態型別檢查,所以是不安全的。
②用於基本資料型別之間的轉換,如把int轉換成char,把int轉換成enum。這種轉換的安全性也要開發人員來保證。
③把空指標轉換成目標型別的空指標。
④把任何型別的表示式轉換成void型別。
注意:static_cast不能轉換掉expression的const、volitale、或者__unaligned屬性。
2.const_cast
用於取出const屬性,把const型別的指標變為非const型別的指標(這和mutable很像,mutable修飾也是去const屬性),如:
const int *fun(int x,int y){}
int *ptr=const_cast(fun(2.3))
用法:const_cast(expression)
該運算子用來修改型別的const或mutable屬性。除了const 或mutable修飾之外, type_id和expression的型別是一樣的。
常量指標被轉化成非常量指標,並且仍然指向原來的物件;
常量引用被轉換成非常量引用,並且仍然指向原來的物件;常量物件被轉換成非常量物件。
mutable
class b
void foo()
上面的**編譯時會報錯,因為b1是乙個常量物件,不能對它進行改變;
使用const_cast把它轉換成乙個非常量物件,就可以對它的資料成員任意改變。注意:b1和b2是兩個不同的物件。
3.dynamic_cast
用法:dynamic_cast < type-id > ( expression )
該運算子把expression轉換成type-id型別的物件。type-id必須是類的指標、類的引用或者void *;
如果type-id是類指標型別,那麼expression也必須是乙個指標,如果type-id是乙個引用,那麼expression也必須是乙個引用。
該操作符用於執行時檢查該轉換是否型別安全,但只在多型型別時合法,即該類至少具有乙個虛擬方法。dynamic_cast與
static_cast具有相同的基本語法,dynamic_cast主要用於類層次間的上行轉換和下行轉換,還可以用於類之間的交叉轉換。在類
層次間進行上行轉換時,dynamic_cast和static_cast的效果是一樣的;在進行下行轉換時,dynamic_cast具有型別檢查的功
能,比static_cast更安全。如:
class b;
class d:public b;
void func(b *pb)
在上面的**段中,如果pb指向乙個d型別的物件,pd1和pd2是一樣的,並且對這兩個指標執行d型別的任何操作都是安全的;
但是,如果pb指向的是乙個b型別的物件,那麼pd1將是乙個指向該物件的指標,對它進行d型別的操作將是不安全的(如訪問m_szname),
而pd2將是乙個空指標。
另外要注意:b要有虛函式,否則會編譯出錯;static_cast則沒有這個限制。
這是由於執行時型別檢查需要執行時型別資訊,而這個資訊儲存在類的虛函式表(
關於虛函式表的概念,詳細可見)中,只有定義了虛函式的類才有虛函式表,
沒有定義虛函式的類是沒有虛函式表的。
另外,dynamic_cast還支援交叉轉換(cross cast)。如下**所示。
class a
};class b:public a;
class d:public a;
void foo()
在函式foo中,使用static_cast進行轉換是不被允許的,將在編譯時出錯;而使用 dynamic_cast的轉換則是允許的,結果是空指標。
4.reinterpret_cast
interpret是解釋的意思,reinterpret即為重新解釋,此識別符號的意思即為資料的二進位制形式重新解釋,但是不改變其值。如:
int i;
char *ptr="hello freind!";
i=reinterpret_cast(ptr);
用法:reinterpret_cast(expression)
type-id必須是乙個指標、引用、算術型別、函式指標或者成員指標。
它可以把乙個指標轉換成乙個整數,也可以把乙個整數轉換成乙個指標(先把乙個指標轉換成乙個整數,
在把該整數轉換成原型別的指標,還可以得到原先的指標值)。
該運算子的用法比較多。
C 中四種型別轉換方式
型別轉換有c風格的,當然還有c 風格的。c風格的轉換的格式很簡單 type expression,但是c風格的型別轉換有不少的缺點,有的時候用c風格的轉換是不合適的,因為它可以在任意型別之間轉換,比如你可以把乙個指向const物件的指標轉換成指向非const物件的指標,把乙個指向基類物件的指標轉換成...
C 中四種型別轉換方式
c 中四種型別轉換方式 型別轉換有c風格的,當然還有c 風格的。c風格的轉換的格式很簡單 type expression,但是c風格的型別轉換有不少的缺點,有的時候用c風格的轉換是不合適的,因為它可以在任意型別之間轉換,比如你可以把乙個指向const物件的指標轉換成指向非const物件的指標,把乙個...
C 中四種型別轉換方式
型別轉換有c風格的,當然還有c 風格的。c風格的轉換的格式很簡單 type expression,但是c風格的型別轉換有不少的缺點,有的時候用c風格的轉換是不合適的,因為它可以在任意型別之間轉換,比如你可以把乙個指向const物件的指標轉換成指向非const物件的指標,把乙個指向基類物件的指標轉換成...