ГЛАВА 6
Классы-коллекции
 

В листинге 5.2 мы разобрали строку на слова. Как их сохранить для дальнейшей обработки?

До сих пор мы пользовались массивами. Они удобны, если необходимо быстро обработать однотипные элементы, например, просуммировать числа, найти наибольшее и наименьшее значение, отсортировать элементы. Но уже для поиска нужных сведений в большом объеме информации массивы неудобны. Для этого лучше использовать бинарные деревья поиска.

Кроме того, массивы всегда имеют постоянную, предварительно заданную, длину, в массивы неудобно добавлять элементы. При удалении элемента из массива оставшиеся элементы следует перенумеровывать.

При решении задач, в которых количество элементов заранее неизвестно, элементы надо часто удалять и добавлять, надо искать другие способы хранения.

В языке Java с самых первых версий есть класс vector , предназначенный для хранения переменного числа элементов самого общего типа object .

 

Класс Vector

 

В классе vector из пакета java.uti i хранятся элементы типа object , а значит, любого типа. Количество элементов может быть любым и наперед не определяться. Элементы получают индексы 0, 1, 2, …. К каждому элементу вектора можно обратиться по индексу, как и к элементу массива.

Кроме количества элементов, называемого размером (size) вектора, есть еще размер буфера — емкость (capacity) вектора. Обычно емкость совпадает с размером вектора, но можно ее увеличить методом e nsureCapacity(int minCapacity) или сравнять с размером вектора методом trimToSize().

В Java 2 класс vector переработан, чтобы включить его в иерархию классов-коллекций. Поэтому многие действия можно совершать старыми и новыми методами. Рекомендуется использовать новые методы, поскольку старые могут быть исключены из следующих версий Java.

 

Как создать вектор

 

В классе четыре конструктора:

vector () — создает пустой объект нулевой длины;

Vector (int capacity) — создает пустой объект указанной емкости capacity ;

vector (int capacity, int increment) — создает пустой объект указанной емкости capacity и задает число increment , на которое увеличивается емкость при необходимости;

vector (Collection с) — вектор создается по указанной коллекции. Если capacity отрицательно, создается исключительная ситуация. После создания вектора его можно заполнять элементами.

 

Как добавить элемент в векторе

 

Метод add (Object element) позволяет добавить элемент в конец вектора

то же делает старый метод addElement (Object element) .

Методом add (int index, Object element) или  старым методом  insertElementAt (Object element, int index) можно вставить элемент В указанное место index . Элемент, находившийся на этом месте, и все последующие элементы сдвигаются, их индексы увеличиваются на единицу.

Метод addAil (Collection coll) позволяет добавить в конец вектора все элементы коллекции coll .

Методом addAii(int index, Collection coll) возможно вставить в позицию index все элементы коллекции coll .

 

Как заменить элемент

 

Метод set (int index, object element) заменяет элемент, стоявший в векторе в позиции index , на элемент element (то же позволяет выполнить старый

метод setElementAt (Object element, int index))

 

Как узнать размер вектора

 

Количество элементов в векторе всегда можно узнать методом size (). Метод capacity о возвращает емкость вектора.

Логический метод isEmpty () возвращает true , если в векторе нет ни одного элемента.

 

Как обратиться к элементу вектора

 

Обратиться к первому элементу вектора можно методом firstEiement () , к последнему — методом lastEiement () , к любому элементу — методом get (int index) или старым методом elementAt (int index).

Эти методы возвращают объект класса object . Перед использованием его следует привести к нужному типу.

Получить все элементы вектора в виде массива типа object[] можно методами toArray( ) и toArray (Object [] а) . Второй метод заносит все элементы вектора в массив а, если в нем достаточно места.

 

Как узнать, есть ли элемент в векторе

 

Логический метод contains (object element) возвращает true , если элемент element находится в векторе.

Логический метод containsAii (Collection с) возвращает true , если вектор содержит все элементы указанной коллекции.

 

Как узнать индекс элемента

 

Четыре метода позволяют отыскать позицию указанного элемента element:

indexof (Object element) — возвращает индекс первого появления элемента в векторе;

indexOf (Object element, int begin) — ведет поиск, начиная с индекса begin включительно;

lastindexOf (object element) — возвращает индекс последнего появления элемента в векторе;

lastindexOf (Object element, int start) — ведет поиск от индекса start включительно к началу вектора.

 

Как удалить элементы

 

Логический метод remove (Object element) удаляет из вектора первое вхождение указанного элемента element . Метод возвращает true , если элемент найден и удаление произведено.

Метод remove (int index) удаляет элемент из позиции index и возвращает его в качестве своего результата типа object .

Аналогичные действия позволяют выполнить старые методы типа void :

removeElement (Object element) И removeElementAt (int index) , не возвращающие результата.

Удалить диапазон элементов можно методом removeRange(int begin, int end) , не возвращающим результата. Удаляются элементы от позиции begin включительно до позиции end исключительно.

Удалить из данного вектора все элементы коллекции coil возможно логическим Методом removeAll(Collection coll).

Удалить последние элементы можно, просто урезав вектор методом

setSizefint newSize).

Удалить все элементы, кроме входящих в указанную коллекцию coil , разрешает логический метод retainAll(Collection coll).

Удалить все элементы вектора можно методом clear () или старым методом

removeAHElements () или  обнулив размер вектора методом setSize(O).

Листинг 6.1 расширяет листинг 5.2, обрабатывая выделенные из строки слова с помощью вектора.

 

 Листинг 6.1. Работа с вектором 

Vector v = new Vector();

String s = «Строка, которую мы хотим разобрать на слова.»;

 StringTokenizer st = new StringTokenizer(s, » \t\n\r,.»);

 while (st.hasMoreTokens()){

   // Получаем слово и заносим в вектор

  v.add(st.nextToken());                                         // Добавляем в конец вектора 

}

System.out.println(v.firstElement());       // Первый элемент 

System.out.println(v.lastElement());        // Последний элемент

 v.setSize(4);                              // Уменьшаем число элементов 

v.add(«собрать.»);                          // Добавляем в конец

                                            // укороченного вектора

v.set(3, «опять»);                          // Ставим в позицию 3 

for (int i = 0; i < v.sizeO; i++)         // Перебираем весь вектор

System.out.print(v.get(i) + » «); 

System.out.println();

Класс vector является примером того, как можно объекты класса object , a значит, любые объекты, объединить в коллекцию. Этот тип коллекции упорядочивает и даже нумерует элементы. В векторе есть первый элемент, есть последний элемент. К каждому элементу обращаются непосредственно по индексу. При добавлении и удалении элементов оставшиеся элементы автоматически перенумеровываются.

Второй пример коллекции — класс stack — расширяет кладе vector .

Если элемент не найден, возвращается —1.