typeid (C++/CLI および C++/CX)typeid (C++/CLI and C++/CX)

オブジェクトの型を示す値を取得します。Gets a value that indicates the type of an object.

注意

このトピックでは、typeid の C++ コンポーネント拡張バージョンを示します。This topic refers to the C++ Component Extensions version of typeid. このキーワードの ISO C++ バージョンについては、「typeid 演算子」を参照してください。For the ISO C++ version of this keyword, see typeid Operator.

すべてのランタイムAll Runtimes

構文Syntax

T::typeid

パラメーターParameters

TT
型の名前。A type name.

Windows ランタイムWindows Runtime

構文Syntax

Platform::Type^ type = T::typeid;

パラメーターParameters

TT
型の名前。A type name.

解説Remarks

C++/CX では、typeid は、ランタイムの型情報から構築された Platform::Type を返します。In C++/CX, typeid returns a Platform::Type that is constructed from runtime type information.

要件Requirements

コンパイラ オプション: /ZWCompiler option: /ZW

共通言語ランタイムCommon Language Runtime

構文Syntax

type::typeid

パラメーターParameters

typetype
System::Type オブジェクトに適用する型 (抽象宣言子) の名前。The name of a type (abstract declarator) for which you want the System::Type object.

解説Remarks

typeid を使用して、コンパイル時に型の Type を取得します。typeid is used to get the Type for a type at compile time.

typeid の機能は、実行時に GetType または GetType を使用して型の System::Type を取得することに似ています。typeid is similar to getting the System::Type for a type at run time using GetType or GetType. ただし、typeid には型名をパラメーターとしてのみ指定できます。However, typeid only accepts a type name as a parameter. 型のインスタンスを使用して、その System::Type 名を取得するには、GetType を使用します。If you want to use an instance of a type to get its System::Type name, use GetType.

typeid はコンパイル時に型名 (型) を評価できる必要がありますが、GetType は実行時に返す型を評価します。typeid must be able to evaluate a type name (type) at compile time, whereas GetType evaluates the type to return at run time.

typeid には、ネイティブ型の名前またはネイティブ型の名前の共通言語ランタイム エイリアスを指定できます。詳細については、「C++ ネイティブ型と等価な .NET Framework ネイティブ型」を参照してください。typeid can take a native type name or common language runtime alias for the native type name; see .NET Framework Equivalents to C++ Native Types (C++/CLI) for more information.

typeid ではネイティブ型も扱えますが、その場合でも System::Type を返します。typeid also works with native types, although it will still return a System::Type. type_info 構造体を取得するには、typeid 演算子を使用します。To get a type_info structure, use typeid Operator.

要件Requirements

コンパイラ オプション: /clrCompiler option: /clr

使用例Examples

次の例では、typeid キーワードと GetType() メンバーを比較します。The following example compares the typeid keyword to the GetType() member.

// keyword__typeid.cpp
// compile with: /clr
using namespace System;

ref struct G {
   int i;
};

int main() {
   G ^ pG = gcnew G;
   Type ^ pType = pG->GetType();
   Type ^ pType2 = G::typeid;

   if (pType == pType2)
      Console::WriteLine("typeid and GetType returned the same System::Type");
   Console::WriteLine(G::typeid);

   typedef float* FloatPtr;
   Console::WriteLine(FloatPtr::typeid);
}
typeid and GetType returned the same System::Type
G

System.Single*

次の例では、System::Type 型の変数を使用して型の属性を取得できることを示しています。The following sample shows that a variable of type System::Type can be used to get the attributes on a type. この例を見るとわかるように、一部の型では、typeid を使用するために typedef を作成する必要があります。It also shows that for some types, you will have to create a typedef to use typeid.

// keyword__typeid_2.cpp
// compile with: /clr
using namespace System;
using namespace System::Security;
using namespace System::Security::Permissions;

typedef int ^ handle_to_int;
typedef int * pointer_to_int;

public ref class MyClass {};

class MyClass2 {};

[attribute(AttributeTargets::All)]
ref class AtClass {
public:
   AtClass(Type ^) {
      Console::WriteLine("in AtClass Type ^ constructor");
   }
};

[attribute(AttributeTargets::All)]
ref class AtClass2 {
public:
   AtClass2() {
      Console::WriteLine("in AtClass2 constructor");
   }
};

// Apply the AtClass and AtClass2 attributes to class B
[AtClass(MyClass::typeid), AtClass2]
[AttributeUsage(AttributeTargets::All)]
ref class B : Attribute {};

int main() {
   Type ^ MyType = B::typeid;

   Console::WriteLine(MyType->IsClass);

   array<Object^>^ MyArray = MyType -> GetCustomAttributes(true);
   for (int i = 0 ; i < MyArray->Length ; i++ )
      Console::WriteLine(MyArray[i]);

   if (int::typeid != pointer_to_int::typeid)
      Console::WriteLine("int::typeid != pointer_to_int::typeid, as expected");

   if (int::typeid == handle_to_int::typeid)
      Console::WriteLine("int::typeid == handle_to_int::typeid, as expected");
}
True

in AtClass2 constructor

in AtClass Type ^ constructor

AtClass2

System.AttributeUsageAttribute

AtClass

int::typeid != pointer_to_int::typeid, as expected

int::typeid == handle_to_int::typeid, as expected

関連項目See also

.NET および UWP でのコンポーネント拡張Component Extensions for .NET and UWP