Méthodes génériques (Guide de programmation C#)

Mise à jour : novembre 2007

Une méthode générique est une méthode qui est déclarée avec des paramètres de type, comme suit :

static void Swap<T>(ref T lhs, ref T rhs)
{
    T temp;
    temp = lhs;
    lhs = rhs;
    rhs = temp;
}

L'exemple de code suivant montre une manière d'appeler la méthode, avec int comme argument de type :

public static void TestSwap()
{
    int a = 1;
    int b = 2;

    Swap<int>(ref a, ref b);
    System.Console.WriteLine(a + " " + b);
}

Vous pouvez également omettre l'argument de type et le compilateur le déduira. L'appel suivant à Swap est équivalent à l'appel précédent :

Swap(ref a, ref b);

Les règles d'inférence de type s'appliquent aux méthodes statiques et aux méthodes d'instance. Le compilateur peut déduire les paramètres de type d'après les arguments de méthode que vous passez. Il ne peut pas déduire les paramètres de type uniquement à partir d'une valeur de contrainte ou de retour. Par conséquent, l'inférence de type ne fonctionne pas avec les méthodes qui n'ont pas de paramètres. L'inférence de type a lieu au moment de la compilation avant que le compilateur essaie de résoudre toute signature de méthode surchargée. Le compilateur applique la logique d'inférence de type à toutes les méthodes génériques qui partagent le même nom. À l'étape de résolution de la surcharge, le compilateur inclut uniquement les méthodes génériques sur lesquelles l'inférence de type a réussi.

Dans une classe générique, les méthodes non génériques peuvent accéder aux paramètres de type de niveau de classe, comme suit :

class SampleClass<T>
{
    void Swap(ref T lhs, ref T rhs) { }
}

Si vous définissez une méthode générique qui accepte les mêmes paramètres de type que la classe conteneur, le compilateur génère l'avertissement CS0693, car, à l'intérieur de la portée de la méthode, l'argument fourni pour le T interne masque l'argument fourni pour le T externe. Si vous avez besoin de la possibilité d'appeler une méthode de classe générique avec des arguments de type différents de ceux qui ont été fournis lorsque la classe a été instanciée, envisagez de fournir un autre identificateur pour le paramètre de type de la méthode, comme indiqué dans GenericList2<T> dans l'exemple suivant.

class GenericList<T>
{
    // CS0693
    void SampleMethod<T>() { }
}

class GenericList2<T>
{
    //No warning
    void SampleMethod<U>() { }
}

Utilisez des contraintes pour activer des opérations plus spécialisées sur les paramètres de type dans les méthodes. Cette version de Swap<T>, maintenant nommée SwapIfGreater<T>, peut s'utiliser uniquement avec des arguments de type qui implémentent IComparable<T>.

void SwapIfGreater<T>(ref T lhs, ref T rhs) where T : System.IComparable<T>
{
    T temp;
    if (lhs.CompareTo(rhs) > 0)
    {
        temp = lhs;
        lhs = rhs;
        rhs = temp;
    }
}

Les méthodes génériques peuvent être surchargées sur plusieurs paramètres de type. Par exemple, toutes les méthodes suivantes peuvent être situées dans la même classe :

void DoWork() { }
void DoWork<T>() { }
void DoWork<T, U>() { }

Spécification du langage C#

Pour plus d'informations, consultez Spécifications du langage C#.

Voir aussi

Concepts

Guide de programmation C#

Référence

Introduction aux génériques (Guide de programmation C#)

System.Collections.Generic

Méthodes (Guide de programmation C#)