Assembly.GetTypes Метод
Определение
Важно!
Некоторые сведения относятся к предварительной версии продукта, в которую до выпуска могут быть внесены существенные изменения. Майкрософт не предоставляет никаких гарантий, явных или подразумеваемых, относительно приведенных здесь сведений.
Возвращает все типы, определенные в этой сборке.
public:
virtual cli::array <Type ^> ^ GetTypes();
public virtual Type[] GetTypes ();
abstract member GetTypes : unit -> Type[]
override this.GetTypes : unit -> Type[]
Public Overridable Function GetTypes () As Type()
Возвращаемое значение
Массив, содержащий все типы, определенные в этой сборке.
Реализации
Исключения
Сборка содержит один или несколько типов, которые не удается загрузить. Массив, возвращаемый свойством Types этого исключения, содержит объект Type для каждого типа, который был загружен, и объект null
для каждого типа, который не удалось загрузить, тогда как свойство LoaderExceptions содержит исключение для каждого типа, который не удалось загрузить.
Примеры
В следующем примере отображаются параметры одного метода для типа в указанной сборке.
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.
array<ParameterInfo^>^ Params = Method->GetParameters();
// Display information about method parameters.
// Param = sParam1
// Type = System::String
// Position = 0
// Optional=False
for each ( ParameterInfo^ Param in Params )
{
Console::WriteLine( "Param= {0}", Param->Name );
Console::WriteLine( " Type= {0}", Param->ParameterType );
Console::WriteLine( " Position= {0}", Param->Position );
Console::WriteLine( " Optional= {0}", Param->IsOptional );
}
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());
}
Dim SampleAssembly As [Assembly]
SampleAssembly = [Assembly].LoadFrom("c:\Sample.Assembly.dll")
' Obtain a reference to a method known to exist in assembly.
Dim Method As MethodInfo = SampleAssembly.GetTypes()(0).GetMethod("Method1")
' Obtain a reference to the parameters collection of the MethodInfo instance.
Dim Params As ParameterInfo() = Method.GetParameters()
' Display information about method parameters.
' Param = sParam1
' Type = System.String
' Position = 0
' Optional=False
For Each Param As ParameterInfo 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()))
Next
Комментарии
Возвращаемый массив включает вложенные и не являющиеся открытыми типы. Чтобы получить только открытые типы, используйте GetExportedTypes метод .
GetTypes Если метод вызывается для сборки и тип в этой сборке зависит от типа в сборке, которая не была загружена (например, если он является производным от типа во второй сборке), ReflectionTypeLoadException возникает исключение . Например, это может произойти, если первая сборка была загружена ReflectionOnlyLoad с помощью методов или ReflectionOnlyLoadFrom , а вторая сборка не была загружена. Это также может произойти со сборками, загруженными с помощью Load методов и LoadFile , если вторая сборка не может быть найдена при вызове GetTypes метода .
Примечание
Если тип был переадресован в другую сборку, он не включается в возвращаемый массив. Сведения о переадресации типов см. в разделе Переадресация типов в СРЕДЕ CLR.
Чтобы получить коллекцию TypeInfo объектов , а не массив объектов Type , используйте Assembly.DefinedTypes свойство .