Contraintes génériques pour distinguer les types valeur et référence
En C#, les contraintes génériques peuvent être utilisées pour appliquer des restrictions sur les paramètres de type. Cependant, lorsque vous tentez de différencier les types valeur, les types valeur nullables et les types référence, l'utilisation de contraintes dans la déclaration du paramètre de type peut ne pas être suffisante.
Contraintes en dehors de la déclaration du paramètre de type
Au lieu de cela, une approche plus efficace consiste à placer la contrainte dans une déclaration de paramètre. Bien que cela puisse paraître non conventionnel, cela permet une résolution des surcharges en fonction des contraintes. Considérons le code suivant :
class RequireStruct<T> where T : struct { } class RequireClass<T> where T : class { } static void Foo<T>(T a, RequireStruct<T> ignore = null) where T : struct { } // Value type static void Foo<T>(T? a) where T : struct { } // Nullable value type static void Foo<T>(T a, RequireClass<T> ignore = null) where T : class { } // Reference type
Dans ce code, les contraintes sont spécifiées dans les déclarations de paramètres. Lorsque vous appelez Foo pour un type valeur (par exemple, int), les première et deuxième méthodes Foo sont viables. La méthode avec la contrainte de type valeur est choisie car elle spécifie un type valeur non nullable (RequireStruct
Exemple d'utilisation
int x = 1; int? y = 2; string z = "a"; Foo(x); // Value type Foo(y); // Nullable value type Foo(z); // Reference type
Cette approche vous permet de différencier efficacement les types valeur, les types valeur nullables et les types référence lors de la résolution de surcharge. Bien que cela puisse paraître peu orthodoxe, cela fournit une solution pratique au problème de la distinction entre ces différents types dans les déclarations de méthodes génériques.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!