命名空间
变体
操作

std::type_info::name

来自 cppreference.cn
< cpp‎ | 类型‎ | 类型信息
 
 
 
 
 
const char* name() const;
(C++11 起无异常抛出)

返回一个实现定义的以 null 结尾的字符字符串,其中包含类型的名称。不作任何保证;特别是,对于几种类型,返回的字符串可能相同,并且在同一程序的多次调用之间可能会更改。

目录

[编辑] 参数

(无)

[编辑] 返回值

以 null 结尾的字符字符串,包含类型的名称。

[编辑] 注意

返回指针所指向的数组的生命周期未指定,但实际上它会持续存在,只要给定类型的 RTTI 数据结构存在,该数据结构具有应用程序生命周期,除非从动态库(可卸载)加载。

一些实现(例如 MSVC、IBM、Oracle)生成人类可读的类型名称。其他实现,最著名的是 gcc 和 clang,返回由 Itanium C++ ABI 指定的混淆名称。混淆名称可以使用实现特定的 API(例如 abi::__cxa_demangle)直接或通过 boost::core::demangle 转换为人类可读的形式。它也可以通过命令行实用程序 c++filt -t 进行管道传输。

[编辑] 示例

#include <boost/core/demangle.hpp>
#include <cstdlib>
#include <iostream>
#include <string>
#include <typeinfo>
 
struct Base { virtual ~Base() = default; };
struct Derived : Base {};
 
int main()
{
    Base b1;
    Derived d1;
 
    const Base* pb = &b1;
    std::cout << typeid(*pb).name() << '\n';
    pb = &d1;
    std::cout << typeid(*pb).name() << '\n';
 
    std::string real_name = boost::core::demangle(typeid(pb).name());
    std::cout << typeid(pb).name() << " => " << real_name << '\n';
 
    std::cout << "c++filt => " << std::flush;
    std::string s = typeid(pb).name();
    std::system(("c++filt -t " + s).data());
}

可能的输出

// GCC/Clang:
4Base
7Derived
PK4Base => Base const*
c++filt => Base const*
 
// MSVC:
struct Base
struct Derived
struct Base const * __ptr64 => struct Base const * __ptr64

[编辑] 参阅

(C++11)
返回对于相同类型相同的哈希值
(public member function) [编辑]