c++四種強制型別轉換

life4711發表於2016-03-22

c++有四種型別的強制型別轉換,所以c++不是型別安全的。分別為: static_cast,dynamic_cast,const_cast,reinterpret_cast

為什麼使用c風格的強制型別轉換可以把想要的任何東西轉換成合乎心意的型別。那為什麼還要一個新的c++型別的強制轉換呢?

新型別的強制轉換可以提供更好的控制強制轉換過程,允許控制各種不同種類的強制轉換。c++中風格是static_cast(content)。c++風格的強制轉換的另一個好處是,它們能清晰的表明它們要幹什麼。

四種強制轉換的區別:

static_cast:可以實現c++中內建基本資料型別之間的相互轉換。

int c=static_cast<int> (7.987);

如果涉及到類的話,static_cast只能在有相互聯絡的型別中進行相互轉換,不一定包含虛擬函式。

class A
{};
class B:public A
{};
class C
{};
int main()
{
    A* a=new A;
    B* b;
    C* c;
    b=static_cast<B>(a);//編譯不會報錯,B類繼承A類
    c=static_cast<B>(a);//編譯報錯,C類與A類沒有任何關係
    return 1;
}

const_cast: const_cast 操作不能再不同的種類間轉換。相反,它僅僅把一個他作用的本來是const型別的資料轉換成const型的,或者把const屬性去掉。
reinterpret_cast:有著和c風格的強制轉換同樣的能力。他可以轉化任何內建的資料型別,也可以轉化任何指標型別為其他的型別。他甚至可以轉化內建的資料型別為指標,無須考慮型別安全或者異常量的情形。不到萬不得已不要用。
dynamic_const :

  1. 其他三種都是編譯完成是的,dynamic_cast是執行時處理的,執行時要進行型別檢查。
  2. 不能用於內建的基本資料型別的強制轉換。
  3. dynamic_cast轉換如果成功的話返回的是指向類的指標或引用,轉換失敗的話返回NULL
  4. 使用dynamic_cast進行轉換的,基類中一定要有虛擬函式,否則編譯不能通過。需要檢測有虛擬函式的原因:類中存在虛擬函式,就說明有想要讓基類指標或引用指向派生類物件的情況,此時轉換才有意義。由於執行時型別檢查需要執行時型別的資訊,而這個資訊儲存在類的虛擬函式表,只有定義了虛擬函式的類才有虛擬函式表。
  5. 在類的轉換時,在類層次間進行上行轉換時,dynamic_cast 和static_cast的效果是一樣的。在進行下行轉換時,dynamic_cast具有型別檢查的功能,比static_cast更安全。向上轉換即為指向子類物件的向下轉換,即將父類指標轉化子類指標。向下轉換的成功與否還與將要轉換的型別有關,即要轉換的指標指向的物件的實際型別與轉換以後的物件型別一定要相同,否則轉換失敗。

相關文章