Informations
Le sujet que vous avez demandé est indiqué ci-dessous. Toutefois, ce sujet ne figure pas dans la bibliothèque.

Type.GetGenericTypeDefinition, méthode

Retourne un objet Type qui représente une définition de type générique à partir de laquelle le type générique actuel peut être construit.

Espace de noms :  System
Assembly :  mscorlib (dans mscorlib.dll)

public virtual Type GetGenericTypeDefinition()

Valeur de retour

Type : System.Type
Objet Type représentant un type générique à partir duquel le type actuel peut être construit.

ExceptionCondition
InvalidOperationException

Le type actuel n'est pas un type générique. En d'autres termes, IsGenericType retourne la valeur false.

NotSupportedException

La méthode appelée n'est pas prise en charge dans la classe de base. Les classes dérivées doivent fournir une implémentation.

Une définition de type générique est un modèle à partir duquel d'autres types peuvent être construits. Par exemple, à partir de la définition de type générique G<T> (exprimée dans la syntaxe C# ; G(Of T) en Visual Basic ou generic <typename T> ref class G en C++) vous pouvez construire et instancier le type G<int> (G(Of Integer) en Visual Basic). À partir de l'objet Type qui représente ce type construit, la méthode GetGenericTypeDefinition retourne la définition de type générique.

Si deux types construits sont créés à partir de la même définition de type générique, à l'aide des mêmes arguments de type, la méthode GetGenericTypeDefinition retourne le même objet Type pour les deux types.

Si vous appelez la méthode GetGenericTypeDefinition sur un objet Type qui représente déjà une définition de type générique, elle retourne le Type actuel.

Remarque importanteImportant

Un tableau de types génériques n'est pas lui-même générique. Dans le A<int>[] v; du code C# ou le Dim v() As A(Of Integer) du code Visual Basic, le type de la variable v n'est pas générique. Utilisez IsGenericType pour déterminer si un type est générique avant d'appeler GetGenericTypeDefinition.

Pour obtenir la liste des conditions invariables des termes utilisés dans une réflexion générique, consultez les notes sur la propriété IsGenericType.

L'exemple de code suivant crée une instance d'un type construit en utilisant la création d'instance ordinaire, puis utilise les méthodes GetType et GetGenericTypeDefinition pour récupérer le type construit et la définition de type générique. Cet exemple utilise le type générique Dictionary<TKey, TValue> ; le type construit représente un Dictionary<TKey, TValue> des objets Test avec des clés de type chaîne.


using System;
using System.Reflection;
using System.Collections.Generic;

public class Test
{
    public static void Main()
    {
        Console.WriteLine("\r\n--- Get the generic type that defines a constructed type.");

        // Create a Dictionary of Test objects, using strings for the
        // keys.       
        Dictionary<string, Test> d = new Dictionary<string, Test>();

        // Get a Type object representing the constructed type.
        //
        Type constructed = d.GetType();
        DisplayTypeInfo(constructed);

        Type generic = constructed.GetGenericTypeDefinition();
        DisplayTypeInfo(generic);
    }

    private static void DisplayTypeInfo(Type t)
    {
        Console.WriteLine("\r\n{0}", t);
        Console.WriteLine("\tIs this a generic type definition? {0}", 
            t.IsGenericTypeDefinition);
        Console.WriteLine("\tIs it a generic type? {0}", 
            t.IsGenericType);
        Type[] typeArguments = t.GetGenericArguments();
        Console.WriteLine("\tList type arguments ({0}):", typeArguments.Length);
        foreach (Type tParam in typeArguments)
        {
            Console.WriteLine("\t\t{0}", tParam);
        }
    }
}

/* This example produces the following output:

--- Get the generic type that defines a constructed type.

System.Collections.Generic.Dictionary`2[System.String,Test]
        Is this a generic type definition? False
        Is it a generic type? True
        List type arguments (2):
                System.String
                Test

System.Collections.Generic.Dictionary`2[TKey,TValue]
        Is this a generic type definition? True
        Is it a generic type? True
        List type arguments (2):
                TKey
                TValue
 */


.NET Framework

Pris en charge dans : 4, 3.5, 3.0, 2.0

.NET Framework Client Profile

Pris en charge dans : 4, 3.5 SP1

Pris en charge dans :

Windows 7, Windows Vista SP1 ou ultérieur, Windows XP SP3, Windows XP SP2 Édition x64, Windows Server 2008 (installation minimale non prise en charge), Windows Server 2008 R2 (installation minimale prise en charge avec SP1 ou version ultérieure), Windows Server 2003 SP2

Le .NET Framework ne prend pas en charge toutes les versions de chaque plateforme. Pour obtenir la liste des versions prises en charge, consultez Configuration requise du .NET Framework.

Ajouts de la communauté

Afficher:
© 2014 Microsoft