Some information on the implementation could be of interest: for g++/clang, the type_info starts with two pointers. The second one points to a fixed character string, which is the value returned by name().
** Note that this implementation is not required by the standard, and may vary across different targets for the same compiler.
Comparison is done by first checking if the type_info are at the same address; if so, they are equal; if not, next call strcmp() on the two 'name' strings. And the strcmp result determines the ordering for .before()
method (and by extension, the ordering for type_index
).
Usually, there is only one type_info in the program for any given type. But, when using shared libraries, it's possible to end up with one in a shared library, and another somewhere else. So, comparing the address is not sufficient to test whether two type_info represent the same type, nor can the address be used for ordering.
If two type_info exist for the same type, their name() will return equivalent character strings, but those strings will be at different addresses, because the string constant and the type_info are generated together.
The .hash_code()
method is disappointing: it calls a function to hash the name()
string, character by character. g++ version calls strlen
to find its len, and then calls the same function used for std::hash(std::string). And this happens even if the type is not unknown, as in e.g. typeid(std::complex<float>).hash_code()
- where the compiler could, in principle, compute the result at compile time.
In my x86_64 clang++-9.0 installation, I'm seeing an odd result - hash_code() returns the same thing as name(), but cast to a size_t. This will often work, but will fail in cases where two type_info for the same type exist in the program. Also, it's not a very rich hash, consider the range of values which occur within a 64-bit address space. It's possible that my installation is somehow getting the wrong header files and this is the result, but it seems to work OK otherwise. Maybe this is an actual defect and nobody uses hash_code() because it's so slow...
I tried another clang-9 for a RISC processor, and it was similar to g++ for hash_code(), but didn't need to call strlen.
operator==
. Better not do that if you aim for portability. – Frontonoperator==
? – Turbidtype_index
to work with the insufferablebefore
member? – Frontonbefore
when just checking for type identity. – Paschalstd:: type_index
. Seems things weren't quite as bad as I recalled. – Fronton