作為四個內(nèi)部類型轉(zhuǎn)換操作符之一的dynamic_cast和傳統(tǒng)的C風(fēng)格的強制類型轉(zhuǎn)換有著巨大的差別。除了dynamic_cast以外的轉(zhuǎn)換,其行為的都是在編譯期就得以確定的,轉(zhuǎn)換是否成功,并不依賴被轉(zhuǎn)換的對象。而dynamic_cast則不然。在這里,不再討論其他三種轉(zhuǎn)換和C風(fēng)格的轉(zhuǎn)換。
首先,dynamic_cast依賴于RTTI信息,其次,在轉(zhuǎn)換時,dynamic_cast會檢查轉(zhuǎn)換的source對象是否真的可以轉(zhuǎn)換成target類型,這種檢查不是語法上的,而是真實情況的檢查。
先看RTTI相關(guān)部分,通常,許多編譯器都是通過vtable找到對象的RTTI信息的,這也就意味著,如果基類沒有虛方法,也就無法判斷一個基類指針變量所指對象的真實類型, 這時候,dynamic_cast只能用來做安全的轉(zhuǎn)換,例如從派生類指針轉(zhuǎn)換成基類指針.而這種轉(zhuǎn)換其實并不需要dynamic_cast參與.
也就是說,dynamic_cast是根據(jù)RTTI記載的信息來判斷類型轉(zhuǎn)換是否合法的.
下面看一個例子:
struct B1{
virtual ~B1(){}
};
struct B2{
virtual ~B2(){}
};
struct D1 : B1, B2{};
int main()
{
D1 d;
B1* pb1 = &d;
B2* pb2 = dynamic_cast<B2*>(pb1);//L1
B2* pb22 = static_cast<B2*>(pb1); //L2
return 0;
}
上述定義中可以看到,B1和B2是不相關(guān)的類,從L1可以看到,dynamic_cast允許這種轉(zhuǎn)換:只要B1存在多態(tài)方法.
L2將編譯失敗,static_cast并不允許兩個完全不相干的類互相轉(zhuǎn)換.
dynamic_cast的這種特性,在提取一個對象的某個接口的時候,非常有用,它很類似于實現(xiàn)了COM的QueryInterface的功能。
正好在網(wǎng)上看到一個講解強制轉(zhuǎn)型的文章:
http://www.xker.com/article/articleview/2005-8-23/article_view_2732.htm
文中這樣描述:
--
dynamic_cast 主要用于執(zhí)行“安全的向下轉(zhuǎn)型(safe downcasting)”,也就是說,要確定一個對象是否是一個繼承體系中的一個特定類型。
---這個描述是不完整的,dynamic_cast 固然可以實現(xiàn)完全的向下轉(zhuǎn)型,也可以實現(xiàn)更為強大的QueryInterface的功能。
本文來自CSDN博客,轉(zhuǎn)載請標(biāo)明出處:http://blog.csdn.net/wingfiring/archive/2006/03/22/633033.aspx