強制轉換:
對於標準c來說 強制轉換為 (type-id)
對於c++來說 提供了另一種強制轉換 static_cast、dynamic_cast、reinterpret_cast、和const_cast
---> static_cast< type-id > ( expression )
該運算子把 expression 轉換為 type-id 型別 但沒有執行時型別檢查來保證轉換的安全性
-> 用於類層次結構中基類和子類之間指標或引用的轉換
進行上行轉換(把子類的指標或引用轉換成基類表示)是安全的
進行下行轉換(把基類指標或引用轉換成子類指標或引用 時 由於沒有動態型別檢查所以是不安全的
-> 用於基本資料型別之間的轉換,如把int轉換成char,把int轉換成enum。這種轉換的安全性也要開發人員來保證
-> 把void指標轉換成目標型別的指標(不安全!!)
-> 把任何型別的表示式轉換成void型別。
---> dynamic_cast< type-id > ( expression )
該運算子把expression轉換成type-id型別的物件 type-id必須是類的指標、類的引用或者void *
如果type-id是類指標型別,那麼expression也必須是乙個指標
如果type-id是乙個引用,那麼expression也必須是乙個引用。
簡單來說 dynamic_cast 是乙個在 "具有虛函式" 的 "基類" 和 "派生類" 之間的互相轉換使用;
他會進行乙個"型別檢查" 即是否可以進行轉換?
在類層次間進行上行轉換時,dynamic_cast和static_cast的效果是一樣的;( 子類轉父類 )
在進行下行轉換時,dynamic_cast具有型別檢查的功能,比static_cast更安全。( 父類轉子類 )
比如:class a
class b : public a
void func( a *a )
如果這個函式 傳入的 a 是乙個 class a 的例項 則轉換失敗 b == nullptr;
如果這個函式 傳入的 a 是乙個 class b 的例項 則轉換成功;
所以 dynamic_cast 主要用於 "無法確定傳入的到底是不是特定子類物件的時候";
用法:#include
class employee
};class manager : public employee
};class programer : public employee
void bones();
};class mycompany
};void programer::bones()
---> reinpreter_cast< type-id > ( expression )
type-id必須是乙個指標、引用、算術型別、函式指標或者成員指標
它可以把乙個指標轉換成乙個整數,也可以把乙個整數轉換成乙個指標
(先把乙個指標轉換成乙個整數,在把該整數轉換成原型別的指標,還可以得到原先的指標值)
---> const_cast< type-id > ( expression )
該運算子用來修改型別的const或volatile屬性。除了const 或volatile修飾之外, type_id和expression的型別是一樣的。
const int temp = 1;
int *p1 = const_cast< int * > ( &temp );
*p1 = 50;
std::cout << *p1;
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.當在...