- Commons Collections - Discussion
- Commons Collections - Useful Resources
- Commons Collections - Quick Guide
- Commons Collections - Union
- Commons Collections - Subtraction
- Commons Collections - Intersection
- Commons Collections - Inclusion
- Commons Collections - Safe Empty Checks
- Commons Collections - Filtering Objects
- Commons Collections - Transforming Objects
- Commons Collections - Merge & Sort
- Commons Collections - Ignore Null
- Commons Collections - OrderedMap Interface
- Commons Collections - MapIterator Interface
- Commons Collections - BidiMap Interface
- Commons Collections - Bag Interface
- Commons Collections - Environment Setup
- Commons Collections - Overview
- Commons Collections - Home
Selected Reading
- Who is Who
- Computer Glossary
- HR Interview Questions
- Effective Resume Writing
- Questions and Answers
- UPSC IAS Exams Notes
Apache Commons Collections - Bag Interface
New Interfaces are added to supports bags. A Bag defines a collection which, counts the number of times an object appears in the collection. For example, if a Bag contains {a, a, b, c} then getCount("a") will return 2 while uniqueSet() returns the unique values.
Interface Declaration
Following is the declaration for org.apache.commons.collections4.Bag<E> interface −
pubpc interface Bag<E> extends Collection<E>
Methods
The methods for bag inference are as follows −
Sr.No. | Method & Description |
---|---|
1 | boolean add(E object) (Violation) Adds one copy of the specified object to the Bag. |
2 | boolean add(E object, int nCopies) Adds nCopies copies of the specified object to the Bag. |
3 | boolean containsAll(Collection<?> coll) (Violation) Returns true if the bag contains all elements in the given collection, respecting cardinapty. |
4 | int getCount(Object object) Returns the number of occurrences (cardinapty) of the given object currently in the bag. |
5 | Iterator<E> iterator() Returns an Iterator over the entire set of members, including copies due to cardinapty. |
6 | boolean remove(Object object) (Violation) Removes all occurrences of the given object from the bag. |
7 | boolean remove(Object object, int nCopies) Removes nCopies copies of the specified object from the Bag. |
8 | boolean removeAll(Collection<?> coll) (Violation) Remove all elements represented in the given collection, respecting cardinapty. |
9 | boolean retainAll(Collection<?> coll) (Violation) Remove any members of the bag that are not in the given collection, respecting cardinapty. |
10 | int size() Returns the total number of items in the bag across all types. |
11 | Set<E> uniqueSet() Returns a Set of unique elements in the Bag. |
Methods Inherited
This interface inherits methods from the following interface −
java.util.Collectio.
Example of Bag Interface
An example of BagTester.java is as follows −
import org.apache.commons.collections4.Bag; import org.apache.commons.collections4.bag.HashBag; pubpc class BagTester { pubpc 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()); } }
Output
You will see the following output −
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]Advertisements