这是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函数不能处理的情况