闲聊C++的RTTI

不少人说,C++的RTTI(Runtime Type Information)的性能不行,或者dynamic_cast的性能不行。

如果这出自C++标准委员会委员之口,那没什么可说的。但是如果出自C++应用开发之口,那就是信口雌黄,人云亦云。

事实上,C++的RTTI的性能可以满足几乎一切的应用开发场景,但是C++的RTTI存在比较严重的设计缺陷。

在C++中,dynamic_cast、运行时类型信息(RTTI)和虚函数之间存在着紧密且复杂的关系:

  • RTTI(Runtime Type Information):RTTI是C++中用于在运行时确定对象的类型的一种机制。它主要通过两个关键功能实现:typeid操作符和dynamic_cast操作符。RTTI允许程序在运行时查询和比较对象的确切类型,这在处理类层次结构中的对象时尤其有用。
  • dynamic_cast:dynamic_cast是RTTI的一个组成部分,它专门用于安全地将指针或引用从一种多态类型转换为另一种。在转换过程中,dynamic_cast会检查所涉及的目标类型是否为源类型的有效子类型。这种转换通常用于类的继承层次结构中,当你需要将基类指针或引用转换为派生类指针或引用,并且需要确保转换的安全性。
  • 虚函数:这种行为是通过虚函数表(v-table)来实现的,每一个多态类都有一个v-table,其中包含了指向类的虚函数的指针。
    为了正确地使用dynamic_cast,必须有一个多态的基类,也就是至少有一个虚函数。没有虚函数的类不支持多态,因此编译器无法为其生成RTTI信息,dynamic_cast也就无法使用。而虚函数的存在意味着每个对象需要携带额外的信息(如v-table指针),这为RTTI的实现提供了必要的信息基础。
    这个设计缺陷容易让缺乏C++经验的人陷入使用误区,例如:
cpp 复制代码
class A {
};
class B : public A {
    virtual void fun() {}
};
int main() {
    A* pB = new B();
    auto pA = dynamic_cast<B*>(pB);
    // error C2683: "dynamic_cast":"A"不是多态类型
}

本质上,C++的RTTI和dynamic_cast是基于虚表技术"买一送一"活动促销获得的。需要深刻理解C++多态思想才能用得得心应手。即使如此,dynamic_cast在跨模块场景支持度差、转换失败可能抛异常的惊人设计,以及其一些隐形规则容易翻车,大部分团队中不会进行广泛推广,而性能最多算个次要因素。

在技术上,我们要多问为什么,敢于挑战权威,深入思考问题的根本,切记不可人云亦云,滥竽充数。问渠那得清如许?为有源头活水来。

相关推荐
D_evil__3 小时前
【Effective Modern C++】第三章 转向现代C++:16. 让const成员函数线程安全
c++
微风中的麦穗3 小时前
【MATLAB】MATLAB R2025a 详细下载安装图文指南:下一代科学计算与工程仿真平台
开发语言·matlab·开发工具·工程仿真·matlab r2025a·matlab r2025·科学计算与工程仿真
2601_949146534 小时前
C语言语音通知API示例代码:基于标准C的语音接口开发与底层调用实践
c语言·开发语言
开源技术4 小时前
Python Pillow 优化,打开和保存速度最快提高14倍
开发语言·python·pillow
学嵌入式的小杨同学4 小时前
从零打造 Linux 终端 MP3 播放器!用 C 语言实现音乐自由
linux·c语言·开发语言·前端·vscode·ci/cd·vim
Queenie_Charlie5 小时前
前缀和的前缀和
数据结构·c++·树状数组
mftang5 小时前
Python 字符串拼接成字节详解
开发语言·python
jasligea6 小时前
构建个人智能助手
开发语言·python·自然语言处理
kokunka6 小时前
【源码+注释】纯C++小游戏开发之射击小球游戏
开发语言·c++·游戏
云栖梦泽7 小时前
易语言开发从入门到精通:补充篇·网络编程进阶+实用爬虫开发·API集成·代理IP配置·异步请求·防封禁优化
开发语言