TreeSet实现了SortedSet也实现了Set,但它不是随便一个对象都能存储:

public class TreeSetTest {
    public static void main(String[] args){
        TreeSet tree = new TreeSet();
        tree.add(new Pepole("zhangsan"));
        tree.add(new Pepole("lisi"));
        
        System.out.println(tree);
    }
}
class Pepole{
    int age;
    String name;
    public Pepole(String name){
        this.name = name;
    }
}

执行上面的代码会得到下面的异常信息:

Exception in thread "main" java.lang.ClassCastException: my.set.Pepole cannot be cast to java.lang.Comparable
    at java.util.TreeMap.put(TreeMap.java:542)
    at java.util.TreeSet.add(TreeSet.java:238)
    at my.set.TreeSetTest.main(TreeSetTest.java:10)

上面的异常出现在往TreeSet里放第二个对象时报的异常,放置第一个的时候没有问题。

放置第二个对象时会用第二对象和TreeSet里的对象进行比较,看是否重复;然而我们自己定义的Pepole没有指定排序规则,所以会抛出异常。

查看TreeSet的add方法可以发现其有这么一个提示:

ClassCastException - 如果指定对象无法与此 set 的当前元素进行比较