Copyright © 2088 2014男篮世界杯_u20世界杯8强 - malajz.com All Rights Reserved.
友情链接
1 首先说明一点 你这样做也不是基类指针访问继承类的成员 仍然是被强制转化为继承类之后才去访问 这样做是不安全的做法 可以考虑使用dynamic_cast进行安全的类型向下转换 甚至可以考虑使用RTTI
2 其实最好的方法是使用虚函数 这点可以在程序设计的时候考虑进去
1.虚函数
2.dynamic_cast
3.强转
不要这么做,会访问错误的,
如果要强访问的话
楼上就可以了
要么你用
if(typeid(类引用)==typeid(子类引用))
成功代码
/*这是从网上摘下的例子,主要讲述了
dynamic_cast<> 的使用方法。*/
/*
作用:将一个基类对象指针(或引用)cast到继承类指针,dynamic_cast会根据基类指针是否真正指向继承类指针来做相应处理,
即会作一定的判断。
对指针进行dynamic_cast,失败返回null,成功返回正常cast后的对象指针;
对引用进行dynamic_cast,失败抛出一个异常,成功返回正常cast后的对象引用。
注意:dynamic_cast在将父类cast到子类时,父类必须要有虚函数。例如在下面的代码中将CBasic类中的test函数不定义成
virtual时,编译器会报错:error C2683: dynamic_cast : “CBasic”不是多态类型
对编译器的要求:
dynamic_cast<> 会用到RTTI技术,因此需要启动“运行时类型信息”这一选项,而在VC.net 2003中默认是关闭的。
所以需要人为的启动这一选项。否则编译器会报下面的警告:
warning C4541: “dynamic_cast”用在了带 /GR- 的多态类型“CBasic”上;
可能导致不可预知的行为从而导致程序在运行时发生异常。
该设置在 Project->Setting中 C/C++ -> C++ Language中设置。
*/
#include
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
//dynamic cast succeeded, so pD2 points to CDerived object
CDerived * pD2 = dynamic_cast
//dynamci cast failed, so throw an exception.
// CDerived & rD1 = dynamic_cast
//dynamic cast succeeded, so rD2 references to CDerived object.
CDerived & rD2 = dynamic_cast
return 0;
}