【C++】面向对象编程(七)RTTI(运行时的鉴定机制):typeid、static_cast、dynamic_cast

RTTI

Run-Time Type Identification,运行时鉴定机制。

typeid运算符

查询多态化的类指针/引用,来获得类指针/引用所指对象的实际类型;

cpp 复制代码
#include <typeinfo>
inline const char* num_sequence::what_am_i() const {return typeid(*this).name();}
//typeid(*this)表达式返回一个type_info对象
//关联到what_am_i()函数中由this指针所指对象
  • typeid运算符会返回一个type_info对象,其中存储着与类型相关的种种信息;
  • 每个多态类(如Fibonacci、Pell等等)都对应一个type_info对象,该对象的name()函数会返回一个const char*用于表示类名:

type_info类

支持相等和不相等两个比较操作;

cpp 复制代码
//测试ps这个基类指针是否指向Fibonacci派生类对象
num_sequence *ps = &fib;
//...
if(typeid(*ps)==typeid(Fibonacci))
//...ok,的确指向Fibonacci派生类对象

//但是
ps->gen_elements(64);//错误
ps->Fibonacci::gen_elems(64);//错误
//ps不是派生类指针

想要用基类指针调用派生类的成员函数,必须把基类指针强制转换为派生类指针:

static_cast运算符

  • 提供无条件转换(基类指针--派生类指针);
  • 潜在危险:编译器无法确定我们所进行的转换操作是否完全正确。(加入if(typeid( *ps ) == typeid( Fibonacci ))条件)
cpp 复制代码
if(typeid( *ps ) == typeid( Fibonacci )) //typeid运算结果为真的条件下
{
	Fibonacci *pf = static_cast<Fibonacci*>(*ps);
	pf->gen_elems(64);//无条件转换
}

dynamic_cast运算符

  • 提供有条件的转换;
  • 在运行时进行检验操作,检验基类指针所指对象是否属于某派生类:
    • 如果是,转换操作便会进行,于是派生类类指针指向了派生类类对象;
    • 如果不是,dynamic_cast运算符返回0,静态调用也就不会发生。
cpp 复制代码
//dynamic_cast在运行时进行检验操作
if(Fibonacci *pf = dynamic_cast<Fibonacci*>(ps))
{
	pf->gen_elems(64);
}
相关推荐
傻啦嘿哟16 小时前
降低首字延迟(TTFB):专线节点与TCP Fast Open的配置
开发语言·php
z落落16 小时前
C#参数区别
java·算法·c#
影寂ldy16 小时前
C#随机数
开发语言·c#
思麟呀17 小时前
C++工业级日志项目(六)异步日志器
linux·c++·windows
c2385617 小时前
vector(下)
数据结构·算法
z落落17 小时前
C# 冒泡排序+选择排序 + Array.Sort 自定义排序
数据结构·算法
wyy1851007372817 小时前
双路并行:一套匹配算法如何解决中文制单的两大核心难题
算法·ai·crm·crm系统
s_w.h17 小时前
【 linux 】文件系统
linux·运维·服务器·算法·bash
PAK向日葵17 小时前
从零实现 Python 虚拟机(二):S.A.A.U.S.O 的总体架构设计
c++·python
无限进步_17 小时前
【C++】weak_ptr、循环引用与线程安全
开发语言·数据结构·c++·算法·安全