c++的四種強制型別轉換,所以c++不是型別安全的.
關鍵字分別是:static_cast,dynamic_cast,const_cast,reinterpret_cast
新型別的強制轉換可以提供更好的控制強制轉換過程,孕育控制各種不同類的強制轉換,c++風格是static_cast(content).c++風格的強制轉換其它的好處是,它們能清晰的表明它們要幹什麼,程式設計師只要掃一眼這樣的**,就立即知道這個強制轉換的目的.
static_cast
可以實現c++中內建基本資料型別之間的相互轉換.
int c=static_cast
(7.98);
如果涉及到類的話,static_cast只能在有相互聯絡的型別中進行相互轉換,不一定包含虛函式
#include
using
namespace
std;
class a
{};class b:public a
{};class c
{};int main()
const_cast
const_cast操作不能在不同的種類之間轉換,它僅僅把乙個它作用的表示式轉換成常量,它可以使乙個本來不是const型別的資料轉換成const型別,或者把const屬性去掉.
#include
struct type
void m1(int v) const
int i;
};int main(int argc,char *argv)
reinterpret_cast
有著和c風格的強制轉換同樣的能力,它可以轉換任何內建的資料型別為其它任何的資料型別,也可以轉換任何指標型別為其它的型別,它甚至可以轉換內建型別為指標,無須考慮型別安全或者常量的情況,不到萬不得已絕不使用.
#include
#include
#include
int f()
int main(int argc,char *argv)
dynamic_cast:
(1) 其它三種都是編譯時完成的,dynamic_cast是執行時處理的,執行要程序型別檢查.
(2)不能用於內建的基本資料型別的強制轉換.
(3)dynamic_cast轉換如果成功的話返回的是指向類的指標或引用,轉換失敗的話則返回null.
(4)使用dynamic_cast進行轉換的,基類中一定要有虛函式,否則編譯不通過.
b中需要檢測有虛函式的原因:類中存在虛函式,就說明它有想要讓基類指標或引用指向派生類物件的情況,此時轉換才有意義.
這是由於執行時型別檢查需要執行時型別資訊,而這個資訊儲存在類的虛函式表中(關於虛函式表的概念)中.
只有定義了虛函式的類才有虛函式表.
(5)在類的轉換時,在類層次之間進行上行轉換時,dynamic_cast和static_cast的效果是一樣的,在進行下行轉換時,dynamic_cast具有型別檢查的功能,比static_cast更安全,向上轉換即為指向子類物件的向下轉換,即將父類指標轉換為子類指標,向下轉換的成功與否還與將要轉換的型別有關,即要轉換的指標指向的物件的實際型別與轉換以後的物件型別一定要相同,否則轉換失敗.
#include
class base
};class derived:public base
};int main(int argc,char *argv)
else
return
1;}
C 四種型別轉換的關鍵字及其特點
c 的四種強制型別轉換,所以c 不是型別安全的。關鍵字分別為 static cast dynamic cast const cast reinterpret cast 為什麼使用c風格的強制轉換可以把想要的任何東西轉換成合乎心意的型別。那為什麼還需要乙個新的c 型別的強制轉換呢?新型別的強制轉換可以...
c 四種型別轉換的關鍵字
1 reinterpret cast expression type id 必須是乙個指標 引用 算術型別 函式指標或者成員指標。它可以把乙個指標轉換成乙個整數,也可以把乙個整數轉換成乙個指標 先把乙個指標轉換成乙個整數,再把該整數轉換成原型別的指標,還可以得到原先的指標值 static cast和...
C 的4種型別轉換關鍵字及其特點
1 reinterpret cast 重解釋轉換 reinterpret cast 轉換乙個指標為其它型別的指標。它也允許從乙個指標轉換為整數型別。反之亦然。這個操作符能夠在非相關的型別之間轉換。操作結果只是簡單的從乙個指標到別的指標的值的二進位制拷貝。在型別之間指向的內容不做任何型別的檢查和轉換。...