C 型別轉換

2021-07-30 22:26:50 字數 1555 閱讀 4041

c風格的強制型別轉換(type cast)很簡單,不管什麼型別的轉換統統是:

type b = (type)a。

c++風格的型別轉換提供了4種型別轉換操作符來應對不同場合的應用。

1.const_cast

去掉const屬性:

#include using namespace std;

class cmyclass

~cmyclass() {}

public:

int m_nnum;

};int main()

如上所見:編譯時型別轉換一般只能提供基類向派生類轉換(指標),在派生類向基類轉換時發生切割現象。其實當沒有虛函式時 dynamic_cast 的作用體現不出來。

dynamic_cast的使用必須注意:

1). 使用虛函式以支援rtti。(已說明)

2).轉換失敗的時候的處理。

dynamic_cast的引數(就是需要轉換的部分)必須是乙個指標或者引用,因為只有通過這兩鐘形式才能獲得執行時的類別。

使用指標時:如果轉換失敗的話dynamic_cast會返回0,所以使用的時候必須加以檢查。

使用引用時:由於不可能給引用賦值為空,所以我們不能通過簡單的=0 來判斷,此時dynamic_cast 轉換失敗時會丟擲bad_cast異常。

4.reinterpret_cast

僅僅重新解釋型別,但沒有進行二進位制的轉換:

1). 轉換的型別必須是乙個指標、引用、算術型別、函式指標或者成員指標。

2). 在位元位級別上進行轉換。它可以把乙個指標轉換成乙個整數,也可以把乙個整數轉換成乙個指標(先把乙個指標轉換成乙個整數,再把該整數轉換成原型別的指標,還可以得到原先的指標值)。但不能將非32bit的例項轉成指標。

3). 最普通的用途就是在函式指標型別之間進行轉換。

4). 很難保證移植性。

int dosomething();

//funcptr 是乙個指向函式的指標,該函式沒有引數,返回值型別為 void

typedef void(*funcptr)();

//10個funcptrs指標的陣列讓我們假設你希望(因為某些莫名其妙的原因)

//把乙個指向下面函式的指標存入funcptrarray陣列:

funcptr funcptrarray[10];

// 如下語句編譯錯誤!型別不匹配,reinterpret_cast可以讓編譯器以你的方法去看待它們:funcptrarray

funcptrarray[0] = &dosomething;

//不同函式指標型別之間進行轉換

funcptrarray[0] = reinterpret_cast(&dosomething);

總結

去const屬性用const_cast。

基本型別轉換用static_cast。

多型類之間的型別轉換用dynamic_cast。

不同型別的指標型別轉換用reinterpret_cast。

mysql型別轉換c 型別轉換 C 型別轉換

一 簡介 型別轉換 把資料從一種型別轉換另一種型別 我們要求等號兩邊參與運算子必須型別一致,如果不一致,滿足下列條件會發生自動型別轉換或者隱式型別轉換。1.兩種型別相容 例如 int和double 相容 都是數字型別 2.目標型別大於源型別 double int 顯示型別轉換 1.兩種型別相相容 i...

C 型別轉換

在程式中,進行型別轉換是常見的事。那麼在 c 中支援以前語言的型別轉換方法,即用型別名進行強行轉換,例如 object objtest new newtype newtype newvalue newtype objtest 但是這樣轉換,有個嚴重的問題,就是在把 objtest 強轉換成 newt...

C 型別轉換

型別轉換是將一種型別的值對映為另一種型別的值。型別轉換實際上包含有自動隱含和強制的兩種。型別的自動隱式轉換 c 語言編譯系統提供的內部資料型別的自動隱式轉換規則如下 1.程式在執行算術運算時,低型別可以轉換為高型別。2.在賦值表示式中,右邊表示式的值自動隱式轉換為左邊變數的型別,並賦值給它。3.當在...