Читаемый человеком type_info.name()

Я скомпилировал следующий код с g++ и получил вывод, написанный в комментариях.

template<class T>
void foo(T t) { cout << typeid(t).name() << endl; }

int main() {
    foo("f");       //emits "PKc"
    foo(string());  //emits "Ss"
}

Я знаю, что type_info.name() не является стандартизированным, но есть ли способ получить удобочитаемые результаты?

Что-то вроде следующего будет достаточно хорошим.

const char *
class string

Ответ 1

Вы можете использовать abi:: __ cxa_demangle для этого (функция demangle, взятая из здесь), просто помните, что вызывающий отвечает за освобождение возврата:

#include <cxxabi.h>
#include <typeinfo>
#include <iostream>
#include <string>
#include <memory>
#include <cstdlib>

std::string demangle(const char* mangled)
{
      int status;
      std::unique_ptr<char[], void (*)(void*)> result(
        abi::__cxa_demangle(mangled, 0, 0, &status), std::free);
      return result.get() ? std::string(result.get()) : "error occurred";
}

template<class T>
void foo(T t) { std::cout << demangle(typeid(t).name()) << std::endl; }

int main() {
    foo("f");            //char const*
    foo(std::string());  //std::string
}

Пример ideone.