в каком-то смысле меньше obj2; нуль, если они считаются равными; положительное число, если obj 1 больше obj 2. Для читателей, знакомых с теорией множеств, скажем, что этот метод сравнения обладает свойствами тождества, антисимметричности и транзитивности;
□ boolean equals(Object obj) — сравнивает данный объект с объектом obj, возвращая true, если объекты совпадают в каком-либо смысле, заданном этим методом.
Для каждой коллекции можно реализовать эти два метода, задав конкретный способ сравнения элементов, и определить объект класса SortedMap вторым конструктором. Элементы коллекции будут автоматически отсортированы в заданном порядке.
Листинг 6.6 показывает один из возможных способов упорядочения комплексных чисел - объектов класса Complex из листинга 2.4. Здесь описывается класс ComplexCompare,
реализующий интерфейс Comparator. В листинге 6.7 он применяется для упорядоченного хранения множества комплексных чисел.
import java.util.*;
class ComplexCompare implements Comparator{
public int compare(Object objl, Object obj2){ Complex zl = (Complex)objl, z2 = (Complex)obj2; double rel = zl.getRe(), iml = zl.getim(); double re2 = z2.getRe(), im2 = z2.getim(); if (rel != re2)
return (int)(rel — re2);
else if (iml != im2)
return (int)(iml — im2); else return 0;
}
public boolean equals(Object z){ return compare(this, z) == 0;
}
}
2. Перепишите листинг 6.3 с использованием классов отображений.
Классы, создающие множества
Класс HashSet полностью реализует интерфейс Set и итератор типа iterator. Класс
HashSet применяется в тех случаях, когда надо хранить только одну копию каждого элемента.
В классе HashSet четыре конструктора:
□ HashSet () — создает пустой объект с показателем загруженности 0,75;
□ HashSet (int capacity) - формирует пустой объект с начальной емкостью capacity и
показателем загруженности 0,75;
□ HashSet (int capacity, float loadFactor) — создает пустой объект с начальной емкостью capacity и показателем загруженности loadFactor;
□ HashSet(Collection coll) — создает объект, содержащий все элементы коллекции coll, с емкостью, равной удвоенному числу элементов коллекции coll, но не менее 11, и показателем загруженности 0,75.
Класс LinkedHashSet полностью реализует интерфейс Set и итератор типа iterator. Класс
реализован как двунаправленный список, значит, его элементы хранятся в упорядоченном виде. Порядок элементов задается последовательностью их занесения в объект.
В классе LinkedHashSet четыре конструктора, которые создают:
□ LinkedHashSet () — пустой объект с емкостью 16 и показателем загруженности 0,75;
□ LinkedHashSet (int capacity) — пустой объект с начальной емкостью capacity и показателем загруженности 0,75;
□ LinkedHashSet (int capacity, float loadFactor) — пустой объект с начальной емкостью capacity и показателем загруженности loadFactor;
□ LinkedHashSet(Collection coll) — объект, содержащий все элементы коллекции coll, с показателем загруженности 0,75.
Класс TreeSet полностью реализует интерфейс SortedSet и итератор типа iterator. Класс TreeSet реализован как бинарное дерево поиска. Это существенно ускоряет поиск нужного элемента.
Порядок задается либо естественным следованием элементов, либо объектом, реализующим интерфейс сравнения Comparator.
Этот класс удобен при поиске элемента во множестве, например для проверки, обладает ли какой-либо элемент свойством, определяющим множество.
В классе TreeSet четыре конструктора, создающих:
□ TreeSet () — пустой объект с естественным порядком элементов;
□ TreeSet (Comparator c) - пустой объект, в котором порядок задается объектом срав
нения c;
□ TreeSet(Collection coll) — объект, содержащий все элементы коллекции coll, с естественным порядком ее элементов;
□ TreeSet(SortedMap sf) — объект, содержащий все элементы отображения sf, в том же порядке.
В листинге 6.7 показано, как можно хранить комплексные числа в упорядоченном виде. Порядок задается объектом класса ComplexCompare, определенного в листинге 6.6.
TreeSet
ts.add(new Complex(l.2, 3.4));
ts.add(new Complex(-l.25, 33.4));
ts.add(new Complex(l.23, -3.45));
ts.add(new Complex(l6.2, 23.4));
iterator it = ts.iterator();
while (it.hasNext())
((Complex)it.next()).pr();
// for (Complex z: ts) z.pr(); // Другой способ обхода множества.
Действия с коллекциями
Коллекции предназначены для хранения элементов в удобном для дальнейшей обработки виде. Очень часто обработка заключается в сортировке элементов и поиске нужного элемента. Эти и другие методы обработки собраны в класс Collections.