C# 4.0 полное руководство - 2011
Шрифт:
}
}
Вот к какому результату приводит выполнение этой программы.
Исходный порядок следования: 54 63 14 98 17 124-10 Порядок следования после сортировки: -101345689141724 Индекс элемента массива со значением 14: 9
В приведенном выше примере массив состоит из элементов типа int, который относится к категории типов значений. Все методы, определенные в классе Array, автоматически доступны для обработки массивов всех встроенных в C# типов значений. Но в отношении массивов ссылок на объекты это правило может и не соблюдаться. Так, для сортировки массива ссылок на объекты в классе типа этих объектов должен быть
В интерфейсе IComparable определяется один метод.
int CompareTo(object obj) .
В этом методе значение вызывающего объекта сравнивается со значением объекта, определяемого параметром obj. Если значение вызывающего объекта больше, чем у объекта obj, то возвращается положительное значение; если оба значения равны — нулевое значение, а если значение вызывающего объекта меньше, чем у объекта obj, — отрицательное значение.
Интерфейс IComparable<T> является обобщенным вариантом интерфейса IComparable. Поэтому в нем определен следующий обобщенный вариант метода CompareTo.
int CompareTo(Т other)
Обобщенный вариант метода CompareTo действует аналогично необобщенному его варианту. В нем значение вызывающего объекта также сравнивается со значением объекта, определяемого параметром other. Если значение вызывающего объекта больше, чем у объекта other, то возвращается положительное значение; если оба значения равны — нулевое значение, а если значение вызывающего объекта меньше, чем у объекта other, — отрицательное значение. Преимущество интерфейса IComparable<T> заключается в том, что он'обеспечивает типовую безопасность, поскольку в этом случае тип обрабатываемых данных указывается явным образом, а следовательно, никакого приведения типа object сравниваемого объекта к нужному типу не требуется. В качестве примера ниже приведена программа, в которой демонстрируются сортировка и поиск в массиве объектов определяемого пользователем класса.
// Отсортировать массив объектов и осуществить в нем поиск, using System;
class MyClass : IComparable<MyClass> { public int i;
public MyClass(int x) { i = x; }
// Реализовать интерфейс IComparable<MyClass>. public int CompareTo(MyClass v) { return i - v.i;
}
public bool Equals(MyClass v) { return i == v.i;
}
class SortDemo {
static void Main {
MyClass[] nums = new MyClass[5];
nums[0] = new MyClass(5); nums[l] = new MyClass (2); nums[2] = new MyClass (3); nums[3] = new MyClass(4); nums[4] = new MyClass(1);
// Отобразить исходный порядок следования.
Console.Write("Исходный порядок следования: "); foreach(MyClass о in nums)
Console.Write(о.i + " ");
Console.WriteLine ;
//
Array.Sort(nums);
// Отобразить порядок следования после сортировки.
Console.Write("Порядок следования после сортировки: "); foreach(MyClass о in nums)
Console.Write(о.i + " ");
Console.WriteLine ;
// Найти объект MyClass (2).
MyClass x = new MyClass (2);
int idx = Array.BinarySearch(nums, x);
Console.WriteLine("Индекс элемента массива с объектом MyClass(2): " + idx) ;
}
}
При выполнении этой программы получается следующий результат.
Исходный порядок следования: 5 2 3 4 1 Порядок следования после сортировки: 12 3 4 5 Индекс элемента массива с объектом MyClass(2): 1
При сортировке или поиске в массиве строк может возникнуть потребность явно указать способ сравнения символьных строк. Так, если массив будет сортироваться с использованием одних настроек культурной среды, а поиск в нем — с помощью других настроек, то во избежание ошибок, скорее всего, придется явно указать способ сравнения. Аналогичная ситуация возникает и в том случае, если требуется отсортировать массив символьных строк при настройках культурной среды, отличающихся от текущих. Для выхода из подобных ситуаций можно передать экземпляр объекта типа StringComparer параметру типа IComparer, который поддерживается в целом ряде перегружаемых вариантов методов Sort () и BinarySearch .
ПРИМЕЧАНИЕ
Более подробно особенности сравнения строк рассматриваются в главе 22.
Класс StringComparer объявляется в пространстве имен System и реализует, среди прочего, интерфейсы IComparer и I Comparer <Т>. Поэтому экземпляр объекта типа StringComparer может быть передан в качестве аргумента параметру типа IComparer. Кроме того, в классе StringComparer определен ряд доступных только для чтения свойств, возвращающих экземпляр объекта типа StringComparer и поддерживающих различные способы сравнения символьных строк. Все эти свойства перечислены ниже.
Свойство
Способ сравнения
public static StringComparer
С учетом регистра и культурной среды
CurrentCulture {get; }
public static StringComparer
Без учета регистра, но с учетом культур
CurrentCulturelgnoreCase {get; }
ной среды
public static StringComparer
С учетом регистра и безотносительно
InvariantCulture {get; }
к культурной среде
public static StringComparer
Без учета регистра и безотносительно
InvariantCulturelgnoreCase {get; }
к культурной среде
public static StringComparer Ordinal
Порядковое сравнение с учетом реги