Posted on 2008-01-20 21:42
MiweiDev 閱讀(2195)
評論(0) 編輯 收藏 引用 所屬分類:
C / C++Language
舊的C風(fēng)格轉(zhuǎn)型幾乎允許你把任何類型轉(zhuǎn)換成任何其他類型(當(dāng)然有些限制)
由于他的功能太強(qiáng)大,對于程序員閱讀這樣的程序會(huì)帶來很大的識別障礙
幾乎所有的工作都用(type)expression的方式進(jìn)行轉(zhuǎn)換
為此C++提供了4種新的轉(zhuǎn)型操作符號(cast operation)
static_cast,const_cast,dynamic_cast和reinterpret_cast
1.static_cast
static_cast基本擁有c風(fēng)格轉(zhuǎn)型差不多的功能,和相同的限制。比如int向double的轉(zhuǎn)換
int testNum;
static_cast<double>testNum;
同樣你也不能將int或者struct轉(zhuǎn)換成pointer,這個(gè)轉(zhuǎn)換在c里面也是不允許的
值得注意的是static_cast不支持const向non-const的互相轉(zhuǎn)換,就是說不能排除表達(dá)式的常量性
const_cast負(fù)責(zé)這一功能
2.const_cast
const_cast專注于這一功能,應(yīng)用面很狹窄,大使增加了可讀性。
class A{...}
class AB:public A{...}
void Update(AB* xy);
AB ab;
const AB& cab = ab;
Update(&cab);//這樣是錯(cuò)誤的
Update(const_cast<CAB*>(&cab));//正確,去掉了常量性
但是 const_cast不支持帶有繼承關(guān)系的轉(zhuǎn)換
A* pa = new AB;
Update(const_cast<AB*>pa);//這樣是錯(cuò)誤的
現(xiàn)在我只需要記住。const_cast最重要的作用就是去除常量性
3.dynamic_cast
用來執(zhí)行繼承體系中安全的向下轉(zhuǎn)型或者跨系轉(zhuǎn)換,上面的操作用dynamic_cast是可以支持的
A* pa = new AB;
Update(dynamic_cast<AB*>pa);
注意的是關(guān)于此操作符的返回值
如果表達(dá)式是pointer ,轉(zhuǎn)換失敗的話會(huì)得到一個(gè)NULL
如果............是ref ,........................會(huì)拋出一個(gè)異常
dynamic_cast只能做這一類型的轉(zhuǎn)換,請不要嘗試去用dynamic_cast改變表達(dá)式的常量性,也無法在缺乏虛函數(shù)的型別上使用(比如int to double,這樣的轉(zhuǎn)換得使用static_cast)
4.reinterpret_cast
這個(gè)我了看的不是很透,資料上說與編譯環(huán)境相關(guān),不具備移植性。
他最常用途是轉(zhuǎn)換(函數(shù)指針)的型別
有一個(gè)保存函數(shù)指針的數(shù)組,里面指針指向函數(shù)的return 都是void
但是你現(xiàn)在有個(gè)函數(shù)return為int,這個(gè)時(shí)候如果你想把這個(gè)函數(shù)放進(jìn)funcPtrArray
如果沒有轉(zhuǎn)型是可能實(shí)現(xiàn)的
typedefine void (*FuncPtr())
int func();
funcPtrArray[0] = &func;//錯(cuò)誤,型別不對
funcPtrArray[0] = reinterpret_cast(FuncPtr)(&func);//正確