typeid用于运行时获取类型信息,需包含头文件;通过typeid(变量).name()获取类型名,可比较类型是否相同;与多态结合时能返回实际对象类型,但类须含虚函数;gcc/clang中需demangle解析可读类型名,MSVC则直接可读;适用于调试和类型识别,但有性能开销和平台差异。

在C++中,typeid 是用于运行时获取对象或数据类型的类型信息的一种机制,它定义在 typeinfo 头文件中。使用 typeid 可以判断变量、表达式或类的类型,常用于调试、日志记录或与多态结合进行类型识别。
包含头文件
要使用 typeid,必须包含标准头文件:
#include
否则编译器会报错:未定义的标识符 ‘typeid’。
基本用法:获取变量类型名
typeid(变量).name() 返回一个表示类型名称的字符串(通常是经过修饰的名称)。
立即学习“C++免费学习笔记(深入)”;
示例:
#include iostream>
#include
using namespace std;
int main() {
int a;
double b;
cout cout return 0;
}
输出可能为:
a 的类型: i
b 的类型: d
注意:.name() 返回的是编译器相关的类型缩写,例如:
i 表示 intd 表示 doublef 表示 floatN1…E 这类可能是类名的mangled name(名称修饰)
使用 typeid 比较类型是否相同
可以直接使用 == 或 != 比较两个 typeid 结果。
示例:
if (typeid(a) == typeid(int)) {
cout }
这在需要根据类型执行不同逻辑时很有用。
与多态和基类指针结合使用
当作用于多态类型的解引用指针时,typeid 能返回实际对象的动态类型(运行时类型),前提是该类至少有一个虚函数。
示例:
#include stream>
#include
using namespace std;
class Base {
public:
virtual ~Base() {} // 必须有虚函数
};
class Derived : public Base {};
int main() {
Base* ptr = new Derived;
cout delete ptr;
return 0;
}
输出可能显示 Derived 类的名称(经过修饰),说明 typeid(*ptr) 获取的是实际对象类型,而不是指针声明类型。
若去掉虚函数,typeid(*ptr) 将只返回 Base 类型。
获取更可读的类型名(demangle)
gcc/clang 中 .name() 返回的是 mangled name。可通过 abi::__cxa_demangle 解析为可读名称。
示例:
#include
#include
#include
#include
template
std::string type_name(const T& t) {
int status;
char* demangled = abi::__cxa_demangle(typeid(t).name(), nullptr, nullptr, &status);
if (status == 0 && demangled != nullptr) {
std::string result(demangled);
free(demangled);
return result;
} else {
return typeid(t).name();
}
}
int main() {
double x = 3.14;
cout return 0;
}
输出:
x 的类型: double
注意:此方法仅适用于支持 ABI 的编译器(如 g++、clang++),MSVC 不需要 demangle,通常直接可读。
基本上就这些。掌握 typeid 有助于在复杂程序中调试类型问题,尤其是在涉及继承和多态时。不过要注意性能开销和跨平台差异。不复杂但容易忽略细节。
以上就是c++++中如何使用typeid获取类型信息_c++ typeid获取类型信息用法的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1479267.html
微信扫一扫
支付宝扫一扫