什么是RTTI
RTTI(Run Time Type Identify)运行时类型检查。就是在运行时知道对象的类型。
实现RTTI的方式
(1)typeid函数
typeid(obj).name()返回对象的类型名称。
(2)dynamic_cast操作符
dynamic_cast可以知道是否可以安全地将对象的地址赋给特定类型的指针。如果转换失败,返回空指针(nullptr)。
注意:
对于类,RTTI只适用于包含虚函数的类。
RTTI实现原理就是根据对象所指向的虚函数表知道对象的类型。
在包含虚函数的类结构中创建的对象,编译器都会自动添加一个指向对应虚函数列表的指针。
示例代码
#ifndef _MAIN_H_
#define _MAIN_H_
#include
class A{
public:
virtual void print(){
std::cout << "A print" << std::endl;
}
void print2(){
std::cout << "A print2" << std::endl;
}
};
class B :public A{
public:
void print(){
std::cout << "B print" << std::endl;
}
};
#endif
#include "main.h"
#include
#include
void main()
{
A* pa(new A);
pa->print();
//通过typeid函数获取对象的类型
std::cout << "pa type is " << typeid(*pa).name() << std::endl;
A* pa2(nullptr);
pa->print2(); //类中的函数是共享的,存在代码区,如果成员函数没使用成员数据则可以通过空指针调用(如果是虚函数则不行)。
B* pb(new B);
pb->print();
std::cout << "pb type is " << typeid(*pb).name() << std::endl;
A* pc = dynamic_cast(pb); //将子类转换为父类
pc->print(); // print是虚函数,所以还是调用B的print函数
std::cout << "pc type is " << typeid(*pc).name() << std::endl;
B* pd = dynamic_cast(pa);// 将父类转换为子类,转换失败返回空指针
if (pd)
{
pd->print();
}
else{
std::cout << "转换失败,返回空指针。" << std::endl;
}
system("pause");
}
1486

被折叠的 条评论
为什么被折叠?



