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.當在...