http://www.shnenglu.com/mzty/archive/2008/02/19/42929.html
一 問(wèn)題1)什么時(shí)候應(yīng)必須使用dynamic_cast2)什么時(shí)候dynamic_cast可以使用static_cast代替二 實(shí)例
// TestCast.cpp : Defines the entry point for the console application.//#include "stdafx.h"#include <iostream>using namespace std;class Base{ public: virtual void f() { cout << "Base::f" << endl; } void f1(){cout << "Base::f1" << endl;}private: double x; double y;};class Derived : public Base{public: virtual void f(){cout << "Derived::f" << endl; } virtual void k(){cout << "Derived::k" << endl; }private: double z;};class Base1{public: virtual void g(){ cout << "Base1::g" << endl;} void g1(){cout << "Base1::g1" << endl;}};class Derived1 : public Base,public Base1{public: virtual void f(){ cout << "Derived1::f" << endl;} virtual void h(){ cout << "Derived1::h" << endl;}};void Test1(){ // 對(duì)于單繼承, // 如果PD真的指向Derived,用dynamic_cast和static_cast效果相同 Base *pD = new Derived; Derived *pD1 = dynamic_cast<Derived*>(pD); pD1->f(); pD1->k(); pD1->f1(); Derived *pD2 = static_cast<Derived*>(pD); pD2->f(); pD2->k(); pD2->f1(); // 但是如果PB不是真的指向Derived,則用dynamic_cast則返回NULL,能夠更早的禁止error的發(fā)生, // 如果用static_cast雖然返回的不為NULL,但是運(yùn)行時(shí)可能拋出exception。 /**///// Error code //Base *pB = new Base(); //Derived *pD3 = static_cast<Derived*>(pB); //pD3->f(); //pD3->k(); //pD3->f1(); //Derived *pD4 = dynamic_cast<Derived*>(pB); //pD4->f(); //pD4->k(); //pD4->f1();}void Test2(){ // 對(duì)于多重繼承, // 如果PD真的指向的是Derived1,使用dynamic_cast和static_cast都可以轉(zhuǎn)化為Derived1, // 但是如果要轉(zhuǎn)化為Base的兄弟類(lèi)Base1,必須使用dynamic_cast,使用static_cast不能編譯。 Base *pD = new Derived1; Derived1 *pD1 = dynamic_cast<Derived1*>(pD); pD1->f(); pD1->h(); pD1->f1(); Base1 *pB1 = dynamic_cast<Base1*>(pD); pB1->g(); Derived1 *pD2 = static_cast<Derived1*>(pD); pD2->f(); pD1->h(); pD2->f1(); /**///// error can not compiler //Base1 *pB2 = static_cast<Base1*>(pD); //pB2->g(); // 當(dāng)然對(duì)于PB不是真的指向Derived1,想要轉(zhuǎn)化為Derived1或Base的兄弟類(lèi)Base1,情況與Test1中的error情況相同。}int _tmain(int argc, _TCHAR* argv[]){ Test1(); Test2(); return 0;}
三 結(jié)論大家先總結(jié)下,哈哈!
posted on 2008-02-19 10:08 夢(mèng)在天涯 閱讀(8227) 評(píng)論(5) 編輯 收藏 引用 所屬分類(lèi): CPlusPlus
# re: dynamic_cast使用的討論 2008-02-19 14:54 rednight
貌似不管啥時(shí)候用dynamic_cast都要安全一些啊 回復(fù) 更多評(píng)論
# re: dynamic_cast使用的討論 2008-02-19 16:08 逍遙劍客
效率上有差別啊 回復(fù) 更多評(píng)論
# re: dynamic_cast使用的討論 2008-02-19 19:20 鍵盤(pán)的詠嘆調(diào)
dynamic_cast依賴(lài)虛函數(shù)并且會(huì)造成運(yùn)行時(shí)的效率缺失 static_cast不依賴(lài)虛函數(shù) 回復(fù) 更多評(píng)論
# re: dynamic_cast使用的討論 2008-07-10 23:46 cexer
在實(shí)際的項(xiàng)目當(dāng)中,可以自己實(shí)現(xiàn)dynamic_cast的運(yùn)行時(shí)安全,并且更具有效率的轉(zhuǎn)換方法。com也能一種。 回復(fù) 更多評(píng)論
# re: dynamic_cast使用的討論 2009-04-10 13:47 qq156875080
上面的我調(diào)試過(guò),不能在VC6.0中調(diào)試通過(guò)的,要進(jìn)行project設(shè)置的(具體設(shè)置可以加我QQ聯(lián)系,注明dynamic) 而且這個(gè)程序是不安全的,new了一個(gè)pD,卻沒(méi)有釋放它,要么采用“test(Base *pD)的書(shū)寫(xiě)形式,要么最后加上“delete pD"操作。 而且對(duì)于你”error code“里面的東西調(diào)試發(fā)現(xiàn),是可以通過(guò)的,只是這時(shí)的PD3獲得的是一個(gè)base類(lèi)型的指針,或者說(shuō)pd3初始化為一個(gè)point to(指向)base的指針,所以這時(shí)pd3對(duì)base的f 和 f1 的調(diào)用是成功的(返回當(dāng)然是base::f 與 base::f1了)。只是在調(diào)用K時(shí)失敗。 個(gè)人理解:動(dòng)態(tài)轉(zhuǎn)換其實(shí)是一個(gè)類(lèi)家族的安全檢查和公共界面問(wèn)題,上面例子知道了一個(gè)類(lèi)的父類(lèi)的時(shí)候,看上去沒(méi)有什么用,你把dynamic和base *都去掉,直接new derived ,結(jié)果還是一樣的。有時(shí)在不知道父類(lèi)時(shí)或者不確定你的類(lèi)是否是父類(lèi)的override時(shí),你在想用這種公共界面,為了類(lèi)型安全(也就是確定他們是一個(gè)家族中的類(lèi)),就要用到這種強(qiáng)制轉(zhuǎn)換 說(shuō)的不好的,望大家指出,一起討論 回復(fù) 更多評(píng)論
posted on 2011-05-04 15:08 肥仔 閱讀(957) 評(píng)論(0) 編輯 收藏 引用 所屬分類(lèi): C++ 基礎(chǔ)
Powered by: C++博客 Copyright © 肥仔