Module.FindTypes(TypeFilter, Object) Méthode
Définition
Important
Certaines informations portent sur la préversion du produit qui est susceptible d’être en grande partie modifiée avant sa publication. Microsoft exclut toute garantie, expresse ou implicite, concernant les informations fournies ici.
Retourne un tableau de classes acceptées par le filtre donné et les critères de filtre.
public:
virtual cli::array <Type ^> ^ FindTypes(System::Reflection::TypeFilter ^ filter, System::Object ^ filterCriteria);
public virtual Type[] FindTypes (System.Reflection.TypeFilter? filter, object? filterCriteria);
public virtual Type[] FindTypes (System.Reflection.TypeFilter filter, object filterCriteria);
abstract member FindTypes : System.Reflection.TypeFilter * obj -> Type[]
override this.FindTypes : System.Reflection.TypeFilter * obj -> Type[]
Public Overridable Function FindTypes (filter As TypeFilter, filterCriteria As Object) As Type()
Paramètres
- filter
- TypeFilter
Le délégué utilisé pour filtrer les classes.
- filterCriteria
- Object
Un objet utilisé pour filtrer les classes.
Retours
Un tableau de type Type
contenant les classes qui ont été acceptées par le filtre.
Exceptions
Une ou plusieurs classes d’un module n’ont pas pu être chargées.
Exemples
L’exemple suivant illustre la FindTypes
méthode.
using namespace System;
using namespace System::Reflection;
using namespace System::Collections;
public ref class MySecondClass{};
// This class does not fit the filter criterion My*.
public ref class YourClass{};
int main()
{
array<Module^>^moduleArray;
moduleArray = Assembly::GetExecutingAssembly()->GetModules( false );
// In a simple project with only one module, the module at index
// 0 will be the module containing these classes.
Module^ myModule = moduleArray[ 0 ];
array<Type^>^tArray;
tArray = myModule->FindTypes( Module::FilterTypeName, "My*" );
IEnumerator^ myEnum = tArray->GetEnumerator();
while ( myEnum->MoveNext() )
{
Type^ t = safe_cast<Type^>(myEnum->Current);
Console::WriteLine( "Found a module beginning with My*: {0}.", t->Name );
}
}
using System;
using System.Reflection;
namespace ReflectionModule_Examples
{
class MyMainClass
{
static void Main()
{
Module[] moduleArray;
moduleArray = typeof(MyMainClass).Assembly.GetModules(false);
// In a simple project with only one module, the module at index
// 0 will be the module containing these classes.
Module myModule = moduleArray[0];
Type[] tArray;
tArray = myModule.FindTypes(Module.FilterTypeName, "My*");
foreach(Type t in tArray)
{
Console.WriteLine("Found a module beginning with My*: {0}.", t.Name);
}
}
}
class MySecondClass
{
}
// This class does not fit the filter criteria My*.
class YourClass
{
}
}
Imports System.Reflection
Namespace ReflectionModule_Examples
Class MyMainClass
Shared Sub Main()
Dim moduleArray() As [Module]
moduleArray = GetType(MyMainClass).Assembly.GetModules(False)
' In a simple project with only one module, the module at index
' 0 will be the module containing these classes.
Dim myModule As [Module] = moduleArray(0)
Dim tArray() As Type
tArray = myModule.FindTypes([Module].FilterTypeName, "My*")
Dim t As Type
For Each t In tArray
Console.WriteLine("Found a module beginning with My*: {0}", t.Name)
Next t
End Sub
End Class
Class MySecondClass
End Class
' This class does not fit the filter criteria My*.
Class YourClass
End Class
End Namespace 'ReflectionModule_Examples
Remarques
ReflectionTypeLoadException est une exception de charge de classe spéciale. La ReflectionTypeLoadException.Types
propriété contient le tableau des classes qui ont été définies dans le module et qui ont été chargées. Ce tableau peut contenir des valeurs null. La ReflectionTypeLoadException.LoaderExceptions
propriété est un tableau d’exceptions qui représentent les exceptions levées par le chargeur de classes. Les trous du tableau de classes s’alignent avec les exceptions.
Le délégué donné par filter
est appelé pour chaque classe du module, en passant l’objet Type
représentant la classe ainsi que le donné filterCriteria
. Si filter
retourne une classe particulière, cette classe sera incluse dans le tableau retourné. Si filter
retourne null
, toutes les classes sont retournées et filterCriteria
sont ignorées.
FindTypes
ne peut pas être utilisé pour rechercher des types paramétrables tels que des tableaux.