一、c語言中的型別轉換
缺陷:轉換的可視性比較差,所有的轉換形式都是以一種相同的形式書寫,難以跟蹤錯誤的轉換
二、c++強制型別轉換
標準c++為了加強型別轉換的可視性,引入了四種命名的強制型別轉換操作符:
static_cast,reinterpret_cast,const_cast,dynamic_cast
2.1 static_cast相近型別
static_cast用於多型型別的轉換(靜態轉換),編譯器隱式執行的任何型別轉換都可用static_cast,但它不能用於兩個不相關的型別進行轉換。
#includeusing namespace std;
int main()
指向上面的**,結果是12.
2.2 reinterpret_cast 不相關型別
reinterpret_cast操作符通常為運算元的位模式提供較低層次的重新解釋,用於將一種型別轉換為另一種不同的型別
#includeusing namespace std;
typedef void(*func) ();
int dosomething(int i)
int main()
2.3 const_castconst_cast最常用的用途就是刪除變數的const屬性,方便賦值
#includeusing namespace std;
int main()
2.4 dynamic_cast 只能用於有虛函式的類dynamic_cast用於將乙個父類物件的指標轉換為子類物件的指標或引用(動態轉換)
向上轉型:子類物件指標->父類指標/引用(不需要轉換,賦值相容)
向下轉型:父類物件指標->子類指標/引用(用danamic_cast轉型是安全的的)
注意:
#includeusing namespace std;
class a
};class b : public a
;void fun(a* pa)
int main()
注意 強制型別轉換關閉或掛起了正常的型別檢查,每次使用強制型別轉換前,程式設計師應該仔細考慮是否還有,其他不同的方法達到同一目的,如果非強制型別轉換不可,則應限制強制轉換值的作用域以減少發生錯誤的機會。
強烈建議:避免使用強制型別轉換
2.5 explicit
explicit關鍵字阻止轉換建構函式進行的隱式型別轉換的發生
#includeusing namespace std;
class a
a(const a* a)
private:
int _a;
};int main()
指向上面的**報錯如下:
c:\users\愛心天使\documents\code\2019-4-26\2019-4-26\test.cpp(217): error c2440: 「初始化」: 無法從「int」轉換為「a」1> class「a」的建構函式宣告為「explicit」
三、為什麼需要強制型別轉換
隱式型別轉換有些情況會出現問題
顯示型別轉換將所有情況混合在一起,**不夠清晰
四、rtti
rtti:run-time type ideftification的簡稱:即:執行時型別識別
c++通過以下的方式來支援rtti
typeid運算子
danamic_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.當在...