2018-05-03 18:41赖鹏举 客户经理
回答这个问题,多半因为楼主这标题中的“小妹”二字,因为干这行的女生太少,既然这样,那必须将这些熊猫保护起来,那么,在下就。。。
这三个类其实考点有这几个,一个是java继承中的重载,一个是compareble这个接口,一个是treeset这个类。
先来讲Compareble这个接口吧,他是JDK提供的一个用于对象之间比较大小的接口。如果你希望你所写的对象是可以比较的,那么就需要提供一种比较的方式。比如:Person这个类,里面有age,name两个属性,你有可能想要按照age来比较,年龄小的排在年龄大的前面。或者你也可以根据名字的字典顺序来比较。这个就可以用Compareble来实现。
再回来看,Compareble接口中有一个compareTo方法,需要接受一个被比较的对象,返回的是一个int型。 返回值分为三类:
>0 表示该值大于所传参数的值
<0 表示该值小于所传参数的值
=0 表示该值等于所传参数的值
比如,一个实现了Compareble接口的对象A。
A a1 = new A();
A a2 = new A();
a1.compareTo(a2) > 0 说明a1大于a2
很自然的,第一个类就解释的通了。
在Parent类中实现了这个compareTo方法,其比较规则是:
age>o1.age?1:age
翻译一下, 这句代码先判断age是否大于o1.age 如果大于,就返回1.
如果不大于,就判断age是否小于o1.age,如果小于就返回-1,
否则就返回0
符合我之前说的 >0 <0 =0 的说法
再来看第二个类,Child 继承了Parent并且重写了compareTo方法,重写为,先输出一句,然后返回1. 意思是无论跟谁比,被比的都要比它小。并且他还有一个特点就是age=3
例如,Child c1 = new Child();
Child c2 = new Child();
c1.compareTo(c2) // 这个结果不管c1 c2是什么情况,都应该认为c1>c2(因为compareTo返回是1,大于0)
反过来c2.compareTo(c1) // c2>c1,因为调用的是c2的方法。
第三个类,考你的是treeSet。 这个数据结构是一个有序的数据结构,你所插入的数据,会自动的排序。 比如你先后插入 2,3,1,6,5,0 最终会有序的排位0,1,2,3,5,6。
而且,他不允许重复值,比如你先插入3,再插入3,那么里面只有一个3,第二个3是插不进去的。
其原理就是调用一个对象的compareTo方法(否则他怎么知道谁大谁小呢)
所以,我们先来比较一下3个被加入treeset的对象的大小情况。
1) set.add(new Parent(3));
2) set.add(new Child());
3) set.add(new Parent(4));
1)号放入的age是3,没任何问题
接着放2)号,将会调用2)号的compareTo方法。而2号之前解释过了,无论怎样他都要比被比较的大,结论是2)号比1)号大。所以2)号放在1)号的后面。
接着放3)号,这里调用的又是parent的compareTo方法,这里比较的就是age的值了,结论是4比3大。那么3)号大于2)号,接着3)号放在2)号的前面。也没问题。
所以最后会有3个对象放入,顺序就是插入的顺序。
(如果都是调用parent中的compareTo,将会出现1号和2号相同,因此2好差不进去,最终set里面只有两个对象。这就是这题的最终考点)
有任何疑问,欢迎提问,乐意解答,为了熊猫。
-------------------------20.55追加--------
以上解释了最后size=3. 也就是最后输出的那个3.
而那四句字符串的输出来源是pearent中的compareTo,和child的compareTo方法。
set.add(new Parent(3)); // 因为之前没有值,所以调用父类的compareTo和null比较,输出method of parent。但是优化后的treeset,在第一个插入的时候不会调用compareTo方法,因为不用比较他也是最小的。所以有可能不会输出第一句。我的机子就不会输出第一句
set.add(new Child()); //这个child对象放入set的时候,里面已经有一个对象,会调用child的compareTo方法,因此会多加一句method of child
set.add(new Parent(4));//调用父类的compareTo方法与第二个插入的比较,输出method of parent,接着调用了compareTo与第一个插入的比较,所以插入第三个的时候比较了两次。输出了两次
答案由此得来。