Прочитать на английском

Поделиться через


IComparable Интерфейс

Определение

Определяет обобщенный метод сравнения, который реализуется типом значения или классом для упорядочения или сортировки экземпляров.

public interface IComparable
[System.Runtime.InteropServices.ComVisible(true)]
public interface IComparable
Производный
Атрибуты

Примеры

В следующем примере показана реализация IComparable и необходимый CompareTo метод.

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

Комментарии

Этот интерфейс реализуется типами, значения которых можно упорядочить или отсортировать. Для реализации типов необходимо определить один метод, CompareTo(Object)который указывает, находится ли позиция текущего экземпляра в порядке сортировки до, после или то же, что и второй объект того же типа. Реализация экземпляра IComparable вызывается автоматически с помощью таких методов, как Array.Sort и ArrayList.Sort.

Реализация CompareTo(Object) метода должна возвращать Int32 одно из трех значений, как показано в следующей таблице.

Значение Значение
Меньше нуля Текущий экземпляр предшествует объекту, указанному CompareTo методом в порядке сортировки.
Нуль Этот текущий экземпляр находится в той же позиции в порядке сортировки, что и объект, заданный методом CompareTo .
Больше нуля Этот текущий экземпляр следует объекту, указанному CompareTo методом в порядке сортировки.

Все числовые типы (например, и Double) реализуют IComparable, как и .DateTimeStringCharInt32 Пользовательские типы также должны предоставлять собственную реализацию для упорядочения IComparable или сортировки экземпляров объектов.

Методы

CompareTo(Object)

Сравнивает текущий экземпляр с другим объектом того же типа и возвращает целое число, которое показывает, расположен ли текущий экземпляр перед, после или на той же позиции в порядке сортировки, что и другой объект.

Применяется к