ЯЗЫК ПРОГРАММИРОВАНИЯ С# 2005 И ПЛАТФОРМА .NET 2.0. 3-е издание
Шрифт:
Вспомним, что класс System.Array определяет статический метод Sort. Вызвав этот метод для массива встроенных типов (int, short, string и т.д.), можно отсортировать элементы в массиве в числовом или алфавитном порядке, поскольку встроенные типы данных реализуют IComparable. Но что произойдет в том случае, когда методу Sort будет передан массив типов Car, как показано ниже?
Запустив этот пример, вы обнаружите, что среда выполнения
Как видите, в CompareTo выполняется сравнение поступившего типа с текущим экземпляром на основе сравнения значений заданных элементов данных. Возвращаемое значение CompareTo указывает, будет ли данный тип меньше, больше или равен объекту сравнения (см. табл. 7.1).
Таблица 7.1. Возвращаемые значения CompareTo
Возвращаемое значение | Описание |
---|---|
Любое число, меньшее нуля | В данном порядке сортировки текущий экземпляр размещается до указанного объекта |
Нуль | Этот экземпляр равен указанному объекту |
Любое число, большее нуля | В данном порядке сортировки текущий экземпляр размещается после указанного объекта |
Теперь, когда тип Car "умеет" сравнивать себя с подобными объектами, вы можете записать пользовательский программный код следующего вида.
На рис. 7.10 показан соответствующий вывод.
Рис. 7.10. Сравнение автомобилей на основе значений ID
Сортировка по набору критериев (IComparer)
В этой версии типа Car в качестве критерия упорядочения мы использовали ID автомобиля, В другом случае для сортировки можно использовать, например, petName (чтобы разместить автомобили в алфавитном порядке их названий). Но что делать, если нужно отсортировать автомобили и по значению ID, и по значению petName? В этом случае вы должны использовать другой стандартный интерфейс, определенный в рамках пространства имен System.Collections, – интерфейс IComparer.
В отличие от IComparable, интерфейс IComparer обычно реализуют не с помощью типов, которые предполагается сортировать (в данном случае это типы Car), а с помощью некоторого набора вспомогательных классов, по одному для каждого порядка сортировки (petName, ID и т.д.). Тип Car (автомобиль) уже "знает", как сравнивать себя с другими автомобилями на основе внутреннего идентификатора ID. Чтобы позволить пользователю объекта отсортировать массив типов Car по значению petName, нам потребуется вспомогательный класс, реализующий IComparer. Вот подходящий для этого программный код.
Этот вспомогательный класс можно использовать в программном коде пользователя объекта. Класс System.Array предлагает перегруженный метод Sort, один из вариантов которого допускает использование объекта, реализующего интерфейс IComparer (рис. 7.11).