c++中有多種型別轉換方式:
強制型別轉換
static_cast
dynamic_cast
reinterpret_cast
const_cast
想怎麼轉就怎麼轉,隨便轉,隨心所欲的**
class
aclass
bint
main()
強制型別轉換其實就是對記憶體的不同解析方式。
這種轉換方式高效便捷,但是沒有編譯時的型別檢查,有可能在呼叫時出錯。
帶安全檢查的型別轉換
同樣是上面的**,下面這句就編譯不過:
b *p =
static_cast
>
(&a)
;// a和b之間沒有繼承關係,不能型別轉換
static_cast用於替代強制型別轉換,此轉換會在編譯時進行型別檢查,而強制轉換不會。
dynamic_cast用於類層次間的上行轉換和下行轉換(基類必須有虛表),除了在編譯器進行型別安全檢查,dynamic_cast還會在執行時型別檢查。
從子類轉為父型別時,dynamic_cast和static_cast是一致的;而從父類轉為子類的過程中,static_cast是非型別安全的,而dynamic_cast會在轉換時做型別安全檢查,若不能轉換則返回null或丟擲異常(在引用型別轉換失敗時丟擲異常)。
class
aclassb:
public a
intmain()
在有虛函式父子類之間互相轉換請使用dynamic_cast。
reinterpret_cast用於進行各種不同型別的指標之間、不同型別的引用之間以及指標和能容納指標的整數型別之間的轉換,轉換不檢查安全性。其實reinterpret_cast和普通強制型別轉換沒多大區別,也不是型別安全的,用reinterpret_cast的好處是:
將強制型別轉換標準化,**看著順眼,而且能快速查詢到強制型別轉換
不改變引數const屬性
僅是將const型別的引數轉換為非const型,不做其他轉換操作;而其他三個型別轉換操作符都不能改變引數的const屬性。
const
char
* str =
"hello world"
;
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.當在...