C 中四種型別轉換方式

2021-06-18 23:57:10 字數 3268 閱讀 3410

型別轉換有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物件的指標,把乙個指向基類物件的指標轉換成...