Skip to content
Related Articles

Related Articles

Improve Article
Save Article
Like Article

How to fix java.lang.ClassCastException while using the TreeMap in Java?

  • Last Updated : 01 Oct, 2021

The java.lang.ClassCastException is one of the unchecked exception in Java. It can occur in our program when we tried to convert an object of one class type into an object of another class type.

When we use custom class objects as keys in the TreeMap and neither implements the comparable interface nor comparator interface, then the java.lang.ClassCastException arises.

Attention reader! Don’t stop learning now. Get hold of all the important Java Foundation and Collections concepts with the Fundamentals of Java and Java Collections Course at a student-friendly price and become industry ready. To complete your preparation from learning a language to DS Algo and many more,  please refer Complete Interview Preparation Course.

So there are two ways to fix java.lang.ClassCastException while using the TreeMap in Java:

Method 1: Using Comparable



We can fix java.lang.ClassCastException by the objects used as keys of the TreeMap implement the Comparable interface.

Pseudo Code:

// Custom class Student implements comparable interface

class Student implements Comparable<Student> {

  String name;
  Integer marks;

  public Student(String name, Integer marks) {
    this.name = name;
    this.marks = marks;
  }

  // Override toString method
  public String toString() {
    return this.name + " : " + this.marks;
  }

  public int getMarks() {
    return this.marks;
  }

  // Override compareTo method that sort treemap in the ascending order of the marks
  public int compareTo(Student stu) {
    return this.getMarks() - stu.getMarks();
  }
}

Implementation:

Java




// Java program to demonstrate how to fix
// java.lang.ClassCastException while using the TreeMap
 
import java.util.*;
 
// Custom class Student implements comparable interface
class Student implements Comparable<Student> {
 
    String name;
    Integer marks;
 
    public Student(String name, Integer marks)
    {
        this.name = name;
        this.marks = marks;
    }
 
    // Override toString method
    public String toString()
    {
        return this.name + " : " + this.marks;
    }
 
    public int getMarks() { return this.marks; }
 
    // Override compareTo method that sort treemap in the
    // ascending order of the marks
    public int compareTo(Student stu)
    {
        return this.getMarks() - stu.getMarks();
    }
}
 
public class GFG {
    public static void main(String[] args)
    {
 
        // New TreeMap
        TreeMap<Student, Integer> map = new TreeMap<>();
 
        map.put(new Student("Akshay", 500), 1);
        map.put(new Student("Bhanu", 600), 2);
        map.put(new Student("Chetan", 300), 3);
 
        System.out.println("The Treemap : " + map);
    }
}
Output
The Treemap : {Chetan : 300=3, Akshay : 500=1, Bhanu : 600=2}

Method 2: Using Comparator

We can fix java.lang.ClassCastException by provide a custom comparator to the constructor at the creation time of the TreeMap.

Pseudo Code: 

// Custom comparator

class MyComparator implements Comparator<Student> {
  // Compare method that sort TreeMap in the ascending order of the marks
  public int compare(Student stu1, Student stu2) {
    return stu1.getMarks() - stu2.getMarks();
  }
}

Implementation: 

Java




// Java program to demonstrate how to fix
// java.lang.ClassCastException while using the TreeMap
 
import java.util.*;
 
// Custom class Student implements comparable interface
class Student {
 
    String name;
    Integer marks;
 
    public Student(String name, Integer marks)
    {
        this.name = name;
        this.marks = marks;
    }
 
    // Override toString method
    public String toString()
    {
        return this.name + " : " + this.marks;
    }
 
    public int getMarks() { return this.marks; }
}
 
// Custom comparator
class MyComparator implements Comparator<Student> {
   
    // Compare method that sort TreeMap in the ascending
    // order of the marks
    public int compare(Student stu1, Student stu2)
    {
        return stu1.getMarks() - stu2.getMarks();
    }
}
 
public class GFG {
    public static void main(String[] args)
    {
 
        // New TreeMap
        TreeMap<Student, Integer> map
            = new TreeMap<>(new MyComparator());
 
        map.put(new Student("Akshay", 500), 1);
        map.put(new Student("Bhanu", 600), 2);
        map.put(new Student("Chetan", 300), 3);
 
        System.out.println("The Treemap : " + map);
    }
}
Output
The Treemap : {Chetan : 300=3, Akshay : 500=1, Bhanu : 600=2}

 




My Personal Notes arrow_drop_up
Recommended Articles
Page :

Start Your Coding Journey Now!