Vector v = new Vector<>(); v.add("First"); v.add("Second");
то возвращается объект именно этого типа и явное приведение типа не требуется, можно написать просто
String s = v.get(1);
Получить все элементы вектора в виде массива типа Object[] можно методами toArray() и toArray(Object[] a). Второй метод заносит все элементы вектора в массив a, если в нем достаточно места.
Как узнать, есть ли элемент в векторе
Логический метод contains(Object element) возвращает true, если элемент element находится в векторе.
Логический метод containsAll(Collection c) возвращает true, если вектор содержит все элементы указанной коллекции.
Как узнать индекс элемента
Четыре метода позволяют отыскать позицию указанного элемента element:
□ indexOf (Object element) — возвращает индекс первого появления элемента в векторе;
□ indexOf (Obj ect element, int begin) - ведет поиск, начиная с индекса begin включи
тельно;
□ lastIndexOf (Obj ect element) — возвращает индекс последнего появления элемента в векторе;
□ lastIndexOf (Obj ect element, int start) - ведет поиск от индекса start включительно
к началу вектора.
Если элемент не найден, возвращается число -1.
Как удалить элементы
Логический метод remove(Object element) удаляет из вектора первое вхождение указанного элемента element. Метод возвращает true, если элемент найден и удаление произведено.
Метод remove(int index) удаляет элемент из позиции index и возвращает его в качестве своего результата типа Object.
Аналогичные действия позволяют выполнить старые методы типа void:
removeElement(Object element) и removeElementAt(int index), не возвращающие результата.
Удалить диапазон элементов можно методом removeRange(int begin, int end), не возвращающим результата. Удаляются элементы от позиции begin включительно до позиции end исключительно.
Удалить из данного вектора все элементы коллекции coll возможно логическим методом removeAll(Collection coll).
Удалить последние элементы можно, просто урезав вектор методом setSize(int newSize).
Удалить все элементы, кроме входящих в указанную коллекцию coll, разрешает логический метод retainAll (Collection coll).
Удалить все элементы вектора можно методом clear(), старым методом removeAllElements ( ) или обнулив размер вектора методом setSize (0).
Приведем пример работы с вектором. Листинг 6.1 расширяет листинг 5.2, обрабатывая выделенные из строки слова с помощью вектора.
Листинг 6.1. Работа с вектором
import java.util.*;
class MyParser{
public static void main(String[] args){
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.size(); i++) // Перебираем весь вектор.
System.out.print(v.get(i) + " ");
System.out.println();
for (String s: v) // Другой способ перебора элементов вектора.
System.out.print(s + " ");
System.out.println();
}
}
Класс Vector является примером того, как можно объекты класса Object, а значит, любые объекты, объединить в коллекцию. Этот тип коллекции упорядочивает и даже нумерует элементы. В векторе есть первый элемент, есть последний элемент. К каждому элементу обращаются непосредственно по индексу. При добавлении и удалении элементов оставшиеся элементы автоматически перенумеровываются.
Класс Stack
Второй пример коллекции-класс Stack-расширяет класс Vector.
Класс Stack из пакета java.util объединяет элементы в стек.
Стек (stack) реализует порядок работы с элементами подобно магазину винтовки — первым выстрелит патрон, положенный в магазин последним, — или подобно железнодорожному тупику — первым из тупика выйдет вагон, загнанный туда последним. Т а-кой порядок обработки называется LIFO (Last In — First Out, последним пришел — первым ушел).
Перед работой создается пустой стек конструктором Stack ().
Затем на стек кладутся и снимаются элементы, причем доступен только "верхний" элемент, тот, что положен на стек последним.
Дополнительно к методам класса Vector класс Stack содержит пять методов, позволяющих работать с коллекцией как со стеком:
Читать дальше
Конец ознакомительного отрывка
Купить книгу