英語で読む

次の方法で共有


Assembly.GetTypes メソッド

定義

このアセンブリで定義されているすべての型を取得します。

C#
public virtual Type[] GetTypes ();

戻り値

Type[]

このアセンブリで定義されているすべての型を格納している配列。

実装

例外

アセンブリには、読み込むことができない 1 つ以上の型が含まれています。 この例外の Types プロパティによって返される配列には、読み込まれた各型の Type オブジェクト、および読み込むことができなかった各型の null が含まれています。LoaderExceptions プロパティには、読み込むことができなかった各型の例外が含まれています。

次の例では、指定したアセンブリ内の型に対する 1 つのメソッドのパラメーターを表示します。

C#
Assembly SampleAssembly;
SampleAssembly = Assembly.LoadFrom("c:\\Sample.Assembly.dll");
// Obtain a reference to a method known to exist in assembly.
MethodInfo Method = SampleAssembly.GetTypes()[0].GetMethod("Method1");
// Obtain a reference to the parameters collection of the MethodInfo instance.
ParameterInfo[] Params = Method.GetParameters();
// Display information about method parameters.
// Param = sParam1
//   Type = System.String
//   Position = 0
//   Optional=False
foreach (ParameterInfo Param in Params)
{
    Console.WriteLine("Param=" + Param.Name.ToString());
    Console.WriteLine("  Type=" + Param.ParameterType.ToString());
    Console.WriteLine("  Position=" + Param.Position.ToString());
    Console.WriteLine("  Optional=" + Param.IsOptional.ToString());
}

注釈

返される配列には、入れ子になった型とパブリックでない型が含まれます。 パブリック型のみを取得するには、 メソッドを使用します GetExportedTypes

メソッドが GetTypes アセンブリで呼び出され、そのアセンブリ内の型が読み込まれていないアセンブリ内の型に依存している場合 (たとえば、2 番目のアセンブリの型から派生した場合) ReflectionTypeLoadException 、 がスローされます。 たとえば、最初のアセンブリが または ReflectionOnlyLoadFrom メソッドでReflectionOnlyLoad読み込まれ、2 番目のアセンブリが読み込まれていない場合に発生する可能性があります。 メソッドの呼び出し時GetTypesに 2 番目のアセンブリがLoad見つからない場合は、 メソッドと LoadFile メソッドを使用して読み込まれたアセンブリでも発生する可能性があります。

注意

型が別のアセンブリに転送されている場合、返される配列には含まれません。 型転送の詳細については、「 共通言語ランタイムでの型の転送」を参照してください。

オブジェクトの配列Typeではなく、オブジェクトのTypeInfoコレクションを取得するには、 プロパティをAssembly.DefinedTypes使用します。

適用対象

製品 バージョン
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.5, 1.6, 2.0, 2.1