Cet article a fait l'objet d'une traduction manuelle. Déplacez votre pointeur sur les phrases de l'article pour voir la version originale de ce texte. |
Traduction
Source
|
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.
Assembly : mscorlib (dans mscorlib.dll)
| Exception | Condition |
|---|---|
| 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.
Important
|
|---|
|
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 */
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.
Important