面试题: TreeSet里面放对象,如果同时放入了父类和子类的实例对象,那比较时使用的是父类的compareTo方法,还是使用的子类的compareTo方法,还是抛异常!
Posted gshao
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了面试题: TreeSet里面放对象,如果同时放入了父类和子类的实例对象,那比较时使用的是父类的compareTo方法,还是使用的子类的compareTo方法,还是抛异常!相关的知识,希望对你有一定的参考价值。
问题:TreeSet里面放对象,如果同时放入了父类和子类的实例对象,那比较时使用的是父类的compareTo方法,还是使用的子类的compareTo方法,还是抛异常!
我个人测试的结果是:当前的add方法 先 放入父类的对象,就会报错。 如果 先 放入子类的对象,则各自调用各自的compareTo()方法进行排序。
至于底层为什么,我暂时还没有弄清楚。。。。。。。哪位大佬可以私聊我。
看代码:
package 测试比较父类子类conpateTo; public class Parent implements Comparable { private String name; private int age; public int getAge(){ return age; } public Parent(){ System.err.println("Parent无参构造器"+name+":"+age); }; public Parent(String name,int age){ this.name=name; this.age=age; System.err.println("Parent双参构造器"+name+":"+age); } //父类年龄升序排列 @Override public int compareTo(Object o) { Parent obj = (Parent)o; return this.age-obj.getAge(); } public String toString(){ return name+":"+age; } }
package 测试比较父类子类conpateTo; public class Children extends Parent { private String name; private int age; public Children(String name, int age) { super(); this.name = name; this.age = age; } //@Override 加上报错 //子类年龄降序排列 public int compareTo(Object o){ Children c=(Children)o; return c.age-this.age; } public String toString(){ return name+":"+age; } }
测试1:
先放入父类任意一个对象,报错 ClassCastException
public class Test { public static void main(String[] args) { TreeSet<Parent> t=new TreeSet(); Parent p=new Parent("Parent1", 45); Parent p1=new Parent("Parent2", 47); Parent p2=new Parent("Parent3", 24); Parent p4=new Parent("Parent4", 22); Children c1=new Children("Jame1",12); Children c2=new Children("Jame2",23); Children c3=new Children("Jame3",46); System.out.println("TreeSet遍历-------"); //先放入父类任意一个对象,报错 ClassCastException t.add(p); t.add(c2); t.add(c1); t.add(p1); t.add(p4); t.add(c3); t.add(p2); Iterator<Parent> iterator=t.iterator(); while(iterator.hasNext()){ System.err.println(iterator.next()); } } }
测试2:
//先放入子类的对象 t.add(c2); t.add(c1); t.add(p1); t.add(p4); t.add(c3); t.add(p); t.add(p2);
输出结果:
Parent双参构造器Parent1:45
Parent双参构造器Parent2:47
Parent双参构造器Parent3:24
Parent双参构造器Parent4:22
Parent无参构造器null:0
Parent无参构造器null:0
Parent无参构造器null:0
TreeSet遍历-------
Jame3:46
Jame2:23
Jame1:12
Parent4:22
Parent3:24
Parent1:45
Parent2:47
以上是关于面试题: TreeSet里面放对象,如果同时放入了父类和子类的实例对象,那比较时使用的是父类的compareTo方法,还是使用的子类的compareTo方法,还是抛异常!的主要内容,如果未能解决你的问题,请参考以下文章
TreeSet简单介绍与使用方法HashSet和TreeSet有什么区别面试题
阿里面试实战题1----TreeSet,HashSet 区别