Apache Commons Collections - Taschenschnittstelle
Unterstützt Taschen werden neue Schnittstellen hinzugefügt. Eine Tasche definiert eine Sammlung, die zählt, wie oft ein Objekt in der Sammlung erscheint. Wenn ein Bag beispielsweise {a, a, b, c} enthält, gibt getCount ("a") 2 zurück, während uniqueSet () die eindeutigen Werte zurückgibt.
Schnittstellendeklaration
Es folgt die Deklaration für die Schnittstelle org.apache.commons.collections4.Bag <E> -
public interface Bag<E>
extends Collection<E>
Methoden
Die Methoden zur Inferenz von Beuteln sind wie folgt:
Sr.Nr. | Methode & Beschreibung |
---|---|
1 | boolean add(E object) (Verletzung) Fügt der Tasche eine Kopie des angegebenen Objekts hinzu. |
2 | boolean add(E object, int nCopies) Fügt der Tasche nCopies-Kopien des angegebenen Objekts hinzu. |
3 | boolean containsAll(Collection<?> coll) (Verletzung) Gibt true zurück, wenn die Tasche alle Elemente in der angegebenen Sammlung enthält, wobei die Kardinalität zu berücksichtigen ist. |
4 | int getCount(Object object) Gibt die Anzahl der Vorkommen (Kardinalität) des aktuell in der Tasche befindlichen Objekts zurück. |
5 | Iterator<E> iterator() Gibt einen Iterator über die gesamte Gruppe von Mitgliedern zurück, einschließlich Kopien aufgrund der Kardinalität. |
6 | boolean remove(Object object) (Verletzung) Entfernt alle Vorkommen des angegebenen Objekts aus der Tasche. |
7 | boolean remove(Object object, int nCopies) Entfernt nCopies-Kopien des angegebenen Objekts aus der Tasche. |
8 | boolean removeAll(Collection<?> coll) (Verletzung) Entfernen Sie alle in der angegebenen Sammlung dargestellten Elemente unter Berücksichtigung der Kardinalität. |
9 | boolean retainAll(Collection<?> coll) (Verstoß) Entfernen Sie alle Mitglieder des Beutels, die sich nicht in der angegebenen Sammlung befinden, unter Berücksichtigung der Kardinalität. |
10 | int size() Gibt die Gesamtzahl der Artikel in der Tasche für alle Typen zurück. |
11 | Set<E> uniqueSet() Gibt eine Reihe eindeutiger Elemente in der Tasche zurück. |
Vererbte Methoden
Diese Schnittstelle erbt Methoden von der folgenden Schnittstelle:
- java.util.Collection
Beispiel für eine Taschenschnittstelle
Ein Beispiel für BagTester.java lautet wie folgt:
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());
}
}
Ausgabe
Sie sehen die folgende Ausgabe -
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]