Module.FindTypes(TypeFilter, Object) Méthode

Définition

Retourne un tableau de classes acceptées par le filtre et les critères de filtre donnés.

public:
 virtual cli::array <Type ^> ^ FindTypes(System::Reflection::TypeFilter ^ filter, System::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

Délégué utilisé pour filtrer les classes.

filterCriteria
Object

Objet utilisé pour filtrer les classes.

Retours

Type[]

Tableau de types Type contenant des classes qui ont été acceptées par le filtre.

Exceptions

Impossible de charger une ou plusieurs classes d’un module.

Exemples

L’exemple suivant illustre la FindTypes méthode.

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 chargement de classe spéciale. La ReflectionTypeLoadException.Types propriété contient le tableau de 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 dans le module, en passant l’objet Type représentant la classe ainsi que le donné filterCriteria. Si filter elle retourne une classe particulière, cette classe sera incluse dans le tableau retourné. Si filter elle est retournée 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.

S’applique à

Voir aussi