C++ 中dynamic_cast<>的使用方法小結(jié)
更新時間:2013年03月05日 10:56:54 作者:
將一個基類對象指針(或引用)cast到繼承類指針,dynamic_cast會根據(jù)基類指針是否真正指向繼承類指針來做相應處理
即會作一定的判斷。
對指針進行dynamic_cast,失敗返回null,成功返回正常cast后的對象指針;
對引用進行dynamic_cast,失敗拋出一個異常,成功返回正常cast后的對象引用。
注意:dynamic_cast在將父類cast到子類時,父類必須要有虛函數(shù)。例如在下面的代碼中將CBasic類中的test函數(shù)不定義成
virtual時,編譯器會報錯:error C2683: dynamic_cast : “CBasic”不是多態(tài)類型
對編譯器的要求:
dynamic_cast<> 會用到RTTI技術(shù),因此需要啟動“運行時類型信息”這一選項,而在VC.net 2003中默認是關(guān)閉的。
所以需要人為的啟動這一選項。否則編譯器會報下面的警告:
warning C4541: “dynamic_cast”用在了帶 /GR- 的多態(tài)類型“CBasic”上;
可能導致不可預知的行為從而導致程序在運行時發(fā)生異常。
該設(shè)置在 Project->Setting中 C/C++ -> C++ Language中設(shè)置。
*/
#include <iostream>
using namespace std;
class CBasic
{
public:
virtual int test(){return 0;} // 一定要是 virtual
};
class CDerived : public CBasic
{
public:
virtual int test(){ return 1;}
};
int main()
{
CBasic cBasic;
CDerived cDerived;
CBasic * pB1 = new CBasic;
CBasic * pB2 = new CDerived;
//dynamic cast failed, so pD1 is null.
CDerived * pD1 = dynamic_cast<CDerived * > (pB1);
//dynamic cast succeeded, so pD2 points to CDerived object
CDerived * pD2 = dynamic_cast<CDerived * > (pB2);
//dynamci cast failed, so throw an exception.
// CDerived & rD1 = dynamic_cast<CDerived &> (*pB1);
//dynamic cast succeeded, so rD2 references to CDerived object.
CDerived & rD2 = dynamic_cast<CDerived &> (*pB2);
return 0;
}
對指針進行dynamic_cast,失敗返回null,成功返回正常cast后的對象指針;
對引用進行dynamic_cast,失敗拋出一個異常,成功返回正常cast后的對象引用。
注意:dynamic_cast在將父類cast到子類時,父類必須要有虛函數(shù)。例如在下面的代碼中將CBasic類中的test函數(shù)不定義成
virtual時,編譯器會報錯:error C2683: dynamic_cast : “CBasic”不是多態(tài)類型
對編譯器的要求:
dynamic_cast<> 會用到RTTI技術(shù),因此需要啟動“運行時類型信息”這一選項,而在VC.net 2003中默認是關(guān)閉的。
所以需要人為的啟動這一選項。否則編譯器會報下面的警告:
warning C4541: “dynamic_cast”用在了帶 /GR- 的多態(tài)類型“CBasic”上;
可能導致不可預知的行為從而導致程序在運行時發(fā)生異常。
該設(shè)置在 Project->Setting中 C/C++ -> C++ Language中設(shè)置。
*/
復制代碼 代碼如下:
#include <iostream>
using namespace std;
class CBasic
{
public:
virtual int test(){return 0;} // 一定要是 virtual
};
class CDerived : public CBasic
{
public:
virtual int test(){ return 1;}
};
int main()
{
CBasic cBasic;
CDerived cDerived;
CBasic * pB1 = new CBasic;
CBasic * pB2 = new CDerived;
//dynamic cast failed, so pD1 is null.
CDerived * pD1 = dynamic_cast<CDerived * > (pB1);
//dynamic cast succeeded, so pD2 points to CDerived object
CDerived * pD2 = dynamic_cast<CDerived * > (pB2);
//dynamci cast failed, so throw an exception.
// CDerived & rD1 = dynamic_cast<CDerived &> (*pB1);
//dynamic cast succeeded, so rD2 references to CDerived object.
CDerived & rD2 = dynamic_cast<CDerived &> (*pB2);
return 0;
}
您可能感興趣的文章:
- C++強制類型轉(zhuǎn)換(static_cast、dynamic_cast、const_cast、reinterpret_cast)
- 淺析C++中dynamic_cast和static_cast實例語法詳解
- C++中的new/delete、構(gòu)造/析構(gòu)函數(shù)、dynamic_cast分析
- 由static_cast和dynamic_cast到C++對象占用內(nèi)存的全面分析
- C++中的類型轉(zhuǎn)換static_cast、dynamic_cast、const_cast和reinterpret_cast總結(jié)
- c++ dynamic_cast與static_cast使用方法示例
- C++的dynamic示例代碼詳解
相關(guān)文章
C++設(shè)置系統(tǒng)時間及系統(tǒng)時間網(wǎng)絡更新的方法
這篇文章主要介紹了C++設(shè)置系統(tǒng)時間及系統(tǒng)時間網(wǎng)絡更新的方法,涉及網(wǎng)絡程序設(shè)計與系統(tǒng)函數(shù)的使用,需要的朋友可以參考下2014-10-10
實例講解C++設(shè)計模式編程中State狀態(tài)模式的運用場景
這篇文章主要介紹了實例講解C++設(shè)計模式編程中State狀態(tài)模式的運用場景,文章最后的適用性部分則介紹了一些State模式善于處理的情況,需要的朋友可以參考下2016-03-03
C++零基礎(chǔ)精通數(shù)據(jù)結(jié)構(gòu)之帶頭雙向循環(huán)鏈表
帶頭雙向循環(huán)鏈表:結(jié)構(gòu)最復雜,一般用在單獨存儲數(shù)據(jù)。實際中使用的鏈表數(shù)據(jù)結(jié)構(gòu),都是帶頭雙向循環(huán)鏈表。另外這個結(jié)構(gòu)雖然結(jié)構(gòu)復雜,但是使用代碼實現(xiàn)以后會發(fā)現(xiàn)結(jié)構(gòu)會帶來很多優(yōu)勢,實現(xiàn)反而簡單2022-03-03

