首頁  >  文章  >  後端開發  >  c++型別轉換

c++型別轉換

angryTom
angryTom原創
2019-10-26 11:02:085669瀏覽

c++型別轉換

c 類型轉換

#在C 語言中,進行類型轉換只需要在變數前面加上變數類型,並且轉換可以是雙向的。例如 int 類型可以轉換為 double 類型,double 類型也可以轉換為 int 類型。 (推薦教學:c 手冊教學

但是這種簡單粗暴的方式在 C 中是不合適的。第一,無法完成C 中的自訂資料型別類;第二,C 語言可以在任意型別之間轉換,例如可以將一個指向const 型物件的指標轉換為指向一個非const 型物件的指針,這對類型檢查非常嚴格的C 來說,顯然是不合理的,所以C 提供了4種特有類型轉換操作符。

1、static_cast

#類似 C 語言中的型別轉換,可以進行無條件型別轉換。應用場景:

基本型別轉換。

int i = 1;
double j = static_cast <double> (i);

父類別和子類別指標之間的轉換。如果父類別指標指向一個對象,此時將父類別指標轉換為子類別指標是不安全的,子類別指標轉換為父類別指標是安全的。

class Base( ) { };
class Derived : public Base { };
Base * p1 = new Base;
Derived * p2 = new Derived;
Derived * p3 = static_cast <Derived *> (p1);      // 不安全
Base * p4 = static_cast <Base *> (p2);  // 安全

將任何類型的表達式轉換為 void 類型。

註:static_cast 無法移除類型的 const 或 volatile 屬性;不能進行無關類型轉換(如非基底類別和子類別)。

2、dynamic_cast

dynamic_cast 只能用於物件指標之間的轉換,轉換結果也可以是應用。在類別層次間進行上行轉換時,dynamic_cast 和 static_cast 的效果是一樣的;在進行下行轉換時,dynamic_cast 具有類型檢查的功能,比 static_cast 更安全。

class Base { virtual void dummy ( ) { } };
class Derived : public Base { };
Base *  b1 = new Base;
Base * b2 = new Derived;
Derived * b3 = dynamic_cast <Derived * > (b1);  //  转换失败,返回 NULL
Derived * b4 = dynamic_cast <Derived * > (b2);  // 转换成功
Derived & b5 = dynamic_cast <Derived & > (b1);   // 转换失败(抛出异常)
Derived & b6 = dynamic_cast <Derived & > (b2);  // 转换成功

註:父子類別指標之間轉換時,此父類別中必須包含一個虛擬函數。

3、const_cast

用於取出 const 屬性,去掉類型的 const 或 volatile 屬性,將 const 類型的指標變成非 const 類型的指標。

const int * fun(int x, int y) { }; 
int * ptr = const_cast < int * > (fun(2, 3));

4、reinterpret_cast

reinterpret_cast 只是重新解釋型別,沒有二進位的轉換。應用:

轉換的型別必須是指標、引用、算術型別、函數指標或成員指標。在比特位級別上進行轉換。它可以把一個指針轉換成一個整數,也可以把一個整數轉換成一個指針(先把一個指針轉換成一個整數,再把該整數轉換成原類型的指針,還可以得到原先的指針值)。但不能將非32bit的實例轉成指標。

一般用在函數指標型別之間轉換。

不能保證可移植性。

附註:此類型轉換不安全,需謹慎使用。

以上是c++型別轉換的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
上一篇:c++基礎知識下一篇:c++基礎知識