型別轉換有 c 風格的,當然還有 c++風格的。c 風格的轉換的格式很簡單(type) expression,但是 c 風格的型別轉換有不少的缺點,有的時候用 c 風格的轉換是不合 適的,因為它可以在任意型別之間轉換,比如你可以把乙個指向 const 物件的指標轉換 成指向非 const 物件的指標,把乙個指向基類物件的指標轉換成指向乙個派生類物件的 指標,這兩種轉換之間的差別是巨大的,但是傳統的 c 語言風格的型別轉換沒有區分這 些。還有乙個缺點就是,c 風格的轉換不容易查詢,他由乙個括號加上乙個識別符號組成, 而這樣的東西在 c++程式裡一大堆。所以 c++為了克服這些缺點,引進了 4 新的型別轉換操作符。
static_cast
靜態型別轉換。
reinterpreter_cast
重新解釋型別轉換。
dynamic_cast
子類和父類之間的多型型別轉換。
const_cast
去掉const屬性轉換
1. static_cast 靜態型別轉換
#include using namespace std;
int main(void)
2. dynamic_cast 子類與父類之間的多型型別準換#includeclass animal ;
class dog : public animal
void dohome() };
class cat : public animal
void dohome() };
int main()
cat* pcat = dynamic_cast(base); //此時轉換成功,成功將父類指標轉換成子類指標
if (pcat != null)
system("pause");
return 0;
}
3. const_cast 去掉const屬性轉換#includeclass a ;
int main()
; a a1 = const_cast(a); //錯誤,const_cast 目標型別只能是引用或者指標
a1.data = 100;
a& a2 = const_cast(a);
a2.data = 100;
std::cout << a.data << ' ' << a2.data << std::endl;
a* a3 = const_cast(&a);
a3->data = 100;
std::cout << a.data << ' ' << a3->data << std::endl;
const int x = 3;
int& x1 = const_cast(x);
x1 = 200;
std::cout << x << ' ' << x1 << std::endl;
int* x2 = const_cast(&x);
*x2 = 300;
std::cout << x << ' ' << *x2 << std::endl;
system("pause");
return 0;
}
reinterpret_cast 重新解釋型別轉換#includeclass animal
};class book
};int main()
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.當在...