Коллекции Apache Commons - интерфейс сумки
Добавлены новые интерфейсы к сумкам опор. Сумка определяет коллекцию, которая подсчитывает количество раз, когда объект появляется в коллекции. Например, если Bag содержит {a, a, b, c}, то getCount ("a") вернет 2, а uniqueSet () вернет уникальные значения.
Объявление интерфейса
Ниже приводится объявление для интерфейса org.apache.commons.collections4.Bag <E> -
public interface Bag<E>
extends Collection<E>
Методы
Методы вывода пакетов следующие:
Sr. No. | Метод и описание |
---|---|
1 | boolean add(E object) (Нарушение) Добавляет одну копию указанного объекта в Сумку. |
2 | boolean add(E object, int nCopies) Добавляет nCopies копии указанного объекта в Сумку. |
3 | boolean containsAll(Collection<?> coll) (Нарушение) Возвращает истину, если сумка содержит все элементы данной коллекции с учетом мощности. |
4 | int getCount(Object object) Возвращает количество вхождений (количество элементов) данного объекта в настоящее время в сумке. |
5 | Iterator<E> iterator() Возвращает итератор по всему набору членов, включая копии в зависимости от количества элементов. |
6 | boolean remove(Object object) (Нарушение) Удаляет все вхождения данного объекта из сумки. |
7 | boolean remove(Object object, int nCopies) Удаляет копии nCopies указанного объекта из мешка. |
8 | boolean removeAll(Collection<?> coll) (Нарушение) Удалить все элементы, представленные в данной коллекции, с учетом количества элементов. |
9 | boolean retainAll(Collection<?> coll) (Нарушение) Удалите из сумки все элементы, не входящие в данную коллекцию, с учетом мощности. |
10 | int size() Возвращает общее количество предметов в сумке для всех типов. |
11 | Set<E> uniqueSet() Возвращает набор уникальных элементов в сумку. |
Унаследованные методы
Этот интерфейс наследует методы из следующего интерфейса -
- java.util.Collection
Пример интерфейса сумки
Пример BagTester.java выглядит следующим образом:
import org.apache.commons.collections4.Bag;
import org.apache.commons.collections4.bag.HashBag;
public class BagTester {
public static void main(String[] args) {
Bag<String> bag = new HashBag<>();
//add "a" two times to the bag.
bag.add("a" , 2);
//add "b" one time to the bag.
bag.add("b");
//add "c" one time to the bag.
bag.add("c");
//add "d" three times to the bag.
bag.add("d",3
//get the count of "d" present in bag.
System.out.println("d is present " + bag.getCount("d") + " times.");
System.out.println("bag: " +bag);
//get the set of unique values from the bag
System.out.println("Unique Set: " +bag.uniqueSet());
//remove 2 occurrences of "d" from the bag
bag.remove("d",2);
System.out.println("2 occurences of d removed from bag: " +bag);
System.out.println("d is present " + bag.getCount("d") + " times.");
System.out.println("bag: " +bag);
System.out.println("Unique Set: " +bag.uniqueSet());
}
}
Выход
Вы увидите следующий вывод -
d is present 3 times.
bag: [2:a,1:b,1:c,3:d]
Unique Set: [a, b, c, d]
2 occurences of d removed from bag: [2:a,1:b,1:c,1:d]
d is present 1 times.
bag: [2:a,1:b,1:c,1:d]
Unique Set: [a, b, c, d]