subMap(K, V): This method is available in java.util.TreeMap class of Java.
Syntax:
SortedMap<K, V> java.util.TreeMap.subMap(K fromKey, V toKey)
This method takes two arguments. This method returns a view of the portion of this map whose keys range from fromKey, inclusive, to toKey, exclusive.
Note: The returned map is backed by this map, so changes in the returned map are reflected in this map, and vice-versa.
Parameters: Two parameters are required for this method.
fromKey: low end point (inclusive) of the keys in the returned map.
toKey: high end point (exclusive) of the keys in the returned map.
Returns: a view of the portion of this map whose keys range from fromKey, inclusive, to toKey, exclusive.
Throws:
1. ClassCastException - if fromKey and toKeycannot be compared to one another using this map's comparator.
2. NullPointerException - if fromKey or toKey is null and this map uses natural ordering, or its comparator does not permit null keys.
3. IllegalArgumentException - if fromKey is greater than toKey; or if this map itself has a restricted range, and fromKey or toKey lies outside the bounds of the range
Approach 1: When no exception
Java
import java.util.TreeMap;public class TreeMapsubMap {public static void main(String[] args) {TreeMap<Integer, String> treeMap =new TreeMap<Integer, String>();treeMap.put(2, "Hello");treeMap.put(11, "Java");treeMap.put(23, "Program");treeMap.put(6, "C++");treeMap.put(25, "Program");Integer fromKey = 2, toKey = 23;System.out.println(treeMap.subMap(fromKey, toKey));}}
Output:
{2=Hello, 6=C++, 11=Java}
Approach 2: NullPointerException
Java
import java.util.TreeMap;public class TreeMapsubMap {public static void main(String[] args) {TreeMap<Integer, String> treeMap =new TreeMap<Integer, String>();treeMap.put(2, "Hello");treeMap.put(11, "Java");treeMap.put(23, "Program");treeMap.put(6, "C++");treeMap.put(25, "Program");Integer fromKey = null, toKey = 23;System.out.println(treeMap.subMap(fromKey, toKey));}}
Output:
Exception in thread "main" java.lang.NullPointerException: Cannot invoke "java.lang.Comparable.compareTo(Object)" because "k1" is null at java.base/java.util.TreeMap.compare(TreeMap.java:1563) at java.base/java.util.TreeMap$NavigableSubMap.<init>(TreeMap.java:1640) at java.base/java.util.TreeMap$AscendingSubMap.<init>(TreeMap.java:2129) at java.base/java.util.TreeMap.subMap(TreeMap.java:1182) at java.base/java.util.TreeMap.subMap(TreeMap.java:1223)
No comments:
Post a Comment