读书人

c++中instanceof用什么代替解决方案

发布时间: 2012-04-01 17:23:46 作者: rapoo

c++中instanceof用什么代替
一个基类型的对象,如何判断它是指向基类还是子类?java中用instanceof,c++中用什么

[解决办法]
这是RTTI(运行阶段类型识别)的问题,c++有三个支持RTTI的元素:
1. dynamic_cast 操作符
如果可能的话,dynamic_cast操作符将使用一个指向基类的指针来生成一个指向派生类的指针;否则,该操作符返回空指针。这是最常用的RTTI组件,它不能回答“指针指向的是哪类对象”这样的问题,但他能回答“是否可以安全地将对象的地址赋给特定类型的指针”这样的问题。如:
class A{}
class B: public A{}
class C: public B{}
然后有下面的指针:
A *a = new A;
B *b = new B;
C *c = new C;
则:
C *cc1 = dynamic_cast<C*>(c); //安全
C *cc2 = dynamic_cast<C*>(a); //cc2是空指针
C *cc3 = dynamic_cast<c*>(b); //cc3是空指针
B *bb = dynamic_cast<C*>(b); //安全
注:只能将此RTTI用于包含虚函数的类层次结构,原因在于只有对于这种类层次结构,才应该将派生类对象的地址赋给基类指针。

2. typeid操作符
3. type_info结构,(须包含头文件<typeinfo>)
class A{}
class B: public A{}
class C: public B{}
然后有下面的指针:
A *pa = new A;
B *pb = new B;
C *pc = new C;
则:
typeid(C) == typeid(pc); //值为true
typeid(B) == typeid(pc); //值为false

type_info有一个name()成员函数,返回一个类名的字符串:
cout << typeid(*pc).name(); //打印C类的类名

注:typeid操作符和name()成员函数都适用于dynamic_cast和virtual函数不能处理的情况
[解决办法]
首先,良好的面向对象设计不应该有instanceof的存身之地
其次,如果实在需要类型判断的话,有很多的选择
如果简单的话可以使用RTTI,设置一个编译器选项
如果是MFC的话,就用MFC的机制吧
如果复杂的应用,那还是自己搞一套机制吧,尽管google的编程规范中明令禁止这种行为,呵呵

读书人网 >C++

热点推荐