C 型別轉換

2021-09-19 23:37:34 字數 2069 閱讀 1690

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