Lire en anglais

Partager via


IComparable Interface

Définition

Définit une méthode de comparaison généralisée spécifique au type qu'un type valeur ou une classe implémente pour ordonnancer ou trier ses instances.

C#
public interface IComparable
C#
[System.Runtime.InteropServices.ComVisible(true)]
public interface IComparable
Dérivé
Attributs

Exemples

L’exemple suivant illustre l’implémentation et IComparable la méthode requise CompareTo .

C#
using System;
using System.Collections;

public class Temperature : IComparable
{
    // The temperature value
    protected double temperatureF;

    public int CompareTo(object obj) {
        if (obj == null) return 1;

        Temperature otherTemperature = obj as Temperature;
        if (otherTemperature != null)
            return this.temperatureF.CompareTo(otherTemperature.temperatureF);
        else
           throw new ArgumentException("Object is not a Temperature");
    }

    public double Fahrenheit
    {
        get
        {
            return this.temperatureF;
        }
        set 
        {
            this.temperatureF = value;
        }
    }

    public double Celsius
    {
        get
        {
            return (this.temperatureF - 32) * (5.0/9);
        }
        set
        {
            this.temperatureF = (value * 9.0/5) + 32;
        }
    }
}

public class CompareTemperatures
{
   public static void Main()
   {
      ArrayList temperatures = new ArrayList();
      // Initialize random number generator.
      Random rnd = new Random();

      // Generate 10 temperatures between 0 and 100 randomly.
      for (int ctr = 1; ctr <= 10; ctr++)
      {
         int degrees = rnd.Next(0, 100);
         Temperature temp = new Temperature();
         temp.Fahrenheit = degrees;
         temperatures.Add(temp);
      }

      // Sort ArrayList.
      temperatures.Sort();

      foreach (Temperature temp in temperatures)
         Console.WriteLine(temp.Fahrenheit);
   }
}
// The example displays the following output to the console (individual
// values may vary because they are randomly generated):
//       2
//       7
//       16
//       17
//       31
//       37
//       58
//       66
//       72
//       95

Remarques

Cette interface est implémentée par des types dont les valeurs peuvent être triées ou triées. Il nécessite que les types implémentent une méthode unique, CompareTo(Object)qui indique si la position de l’instance actuelle dans l’ordre de tri est avant, après, ou identique à un deuxième objet du même type. L’implémentation de l’instance IComparable est appelée automatiquement par des méthodes telles que Array.Sort et ArrayList.Sort.

L’implémentation de la CompareTo(Object) méthode doit retourner une Int32 valeur dont l’une des trois valeurs est indiquée dans le tableau suivant.

Value Signification
Inférieure à zéro L’instance actuelle précède l’objet spécifié par la méthode dans l’ordre CompareTo de tri.
Zéro Cette instance actuelle se produit à la même position dans l’ordre de tri que l’objet spécifié par la CompareTo méthode.
Supérieure à zéro Cette instance actuelle suit l’objet spécifié par la CompareTo méthode dans l’ordre de tri.

Tous les types numériques (tels que Int32 et Double) implémentent IComparable, comme le Stringfont, Charet DateTime. Les types personnalisés doivent également fournir leur propre implémentation pour IComparable permettre aux instances d’objets d’être triées ou triées.

Méthodes

CompareTo(Object)

Compare l'instance actuelle avec un autre objet du même type et retourne un entier qui indique si l'instance actuelle précède ou suit un autre objet ou se trouve à la même position dans l'ordre de tri.

S’applique à

Produit Versions
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7
.NET Framework 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.5, 1.6, 2.0, 2.1
UWP 10.0