typeid
読み:タイプ-アイディー
外語:typeid

 C++の予約語の一つ。
 オブジェクトの型情報であるtype_info型オブジェクトを得る演算子
目次

文法
 #include <typeinfo>

概要
 C++は、動的に型情報を取得する機構として実行時型情報(RTTI)というものが用意されている。
 RTTIのためにtype_infoクラスが用意されており、標準C++ライブラリのtypeinfoをincludeすることで利用できるようになる。
 typeid演算子は、const type_infoの参照を戻す。

特徴

定義
 type_infoクラスには内部的な機能などもあるが、公開され、広く利用されるものは、オーバーロードされた二つの演算子(==演算子、!=演算子)と、次のメソッドである。
 const char *name() const
 これは、次のように使う。
 std::cout << typeid(i).name() << std::endl;
 iの部分は、変数名等の他、intなどの変数型を直接書いても良いし、即値でも良い。

nameメソッド
 結果はchar *、つまりASCIIZ形式で返される。
 内容については完全に処理系依存である。
 intを "int" と返す実装もあれば、"i" と記号で返す実装もあり、多様である。
 FreeBSDのg++(GCC)では、次のような記号を返す。
 char *なら "Pc"、const char *なら "PKc" になる。
 classstructは、その名前が返される。例えばclass Hogeに対するポインターは、クラス名が4文字なので、"P4Hoge" となる。
 registerautostaticなどの修飾は結果に現われないが、constはK、volatileはVが出力されている。
 文字列を即値で与える(例えばtypeid("hoge").name()など)と、NUL末端を含めた文字列長と、charかwchar_tかの識別子が出力される。例えば、"A5_c" などとなる。

複雑な場合
 関数やnamespace内のclassなどの場合、複雑な出力になる。
 関数は、int hoge()であれば "FivE"、int main(int argc, char**argv)であれば "FiiPPcE" のようになる。
 namespaceでは、namespace fuga内のclass hogeなら "N4fuga4hogeE" と出力される。

再検索