The retainAll() method of java.util.Set interface is used to retain from this set all of its elements that are contained in the specified collection.
Syntax:
public boolean retainAll(Collection c)
Parameters: This method takes collection c as a parameter containing elements to be retained from this set.
Return Value: This method returns true if this set changed as a result of the call.
Exception: This method throws NullPointerException if this set contains a null element and the specified collection does not permit null elements (optional), or if the specified collection is null.
Below are the examples to illustrate the retainAll() method.
Example 1:
// Java program to demonstrate // retainAll() method for Integer value import java.util.*; public class GFG1 { public static void main(String[] argv) throws Exception { try { // Creating object of Set Set<Integer> arrset1 = new HashSet<Integer>(); // Populating arrset1 arrset1.add( 1 ); arrset1.add( 2 ); arrset1.add( 3 ); arrset1.add( 4 ); arrset1.add( 5 ); // print arrset1 System.out.println( "Set before retainAll() operation : " + arrset1); // Creating another object of Set Set<Integer> arrset2 = new HashSet<Integer>(); arrset2.add( 1 ); arrset2.add( 2 ); arrset2.add( 3 ); // print arrset2 System.out.println( "Collection Elements to be retained : " + arrset2); // Removing elements from arrset // specified in arrset2 // using retainAll() method arrset1.retainAll(arrset2); // print arrset1 System.out.println( "Set after retainAll() operation : " + arrset1); } catch (NullPointerException e) { System.out.println( "Exception thrown : " + e); } } } |
Set before retainAll() operation : [1, 2, 3, 4, 5] Collection Elements to be retained : [1, 2, 3] Set after retainAll() operation : [1, 2, 3]
Example 2: For NullPointerException.
// Java program to demonstrate // retainAll() method for Integer value import java.util.*; public class GFG1 { public static void main(String[] argv) throws Exception { try { // Creating object of Set<Integer> Set<Integer> arrset1 = new HashSet<Integer>(); // Populating arrset1 arrset1.add( 1 ); arrset1.add( 2 ); arrset1.add( 3 ); arrset1.add( 4 ); arrset1.add( 5 ); // print arrset1 System.out.println( "Set before retainAll() operation : " + arrset1); // Creating another object of Set<Integer> Set<Integer> arrset2 = null ; // print arrset2 System.out.println( "Collection Elements to be retained : " + arrset2); System.out.println( "\nTrying to pass " + "null as a specified element\n" ); // Removing elements from arrset // specified in arrset2 // using retainAll() method arrset1.retainAll(arrset2); // print arrset1 System.out.println( "Set after retainAll() operation : " + arrset1); } catch (NullPointerException e) { System.out.println( "Exception thrown : " + e); } } } |
Set before retainAll() operation : [1, 2, 3, 4, 5] Collection Elements to be retained : null Trying to pass null as a specified element Exception thrown : java.lang.NullPointerException
Reference: https://docs.oracle.com/javase/7/docs/api/java/util/Set.html#retainAll(java.util.Collection)