A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 920792433 中级黑马   /  2015-10-8 10:46  /  1452 人查看  /  6 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

Treeset集合排序有两种方式,comparable和comparetor的区别,什么时候用哪一个?求大神讲详细点,我有点不懂。

6 个回复

倒序浏览
Comparable用于默认排序行为
Comparator用于自定义、多样化排序行为

一个类只能实现一次Comparable接口,但可以有多个Comparator
Comparator覆盖Comparable行为(可以类比个性化定制,手机盖有个出厂的默认样式,但不同用户可以定制自己的手机盖)
回复 使用道具 举报
楼上详细。 Comparator优先于Comparable
回复 使用道具 举报
comparetor介个常用
回复 使用道具 举报
匿名类构造comparetor优先于comparable
回复 使用道具 举报
TreeSet会调用集合元素的compareTo(Object obj)方法来比较元素之间大小关系,然后将集合元素按升序排列,这种方式就是自然排序。(比较的前提:两个对象的类型相同)。
java提供了一个Comparable接口,该接口里定义了一个compareTo(Object obj)方法,该方法返回一个整数值,实现该接口的类必须实现该方法,实现了该接口的类的对象就可以比较大小。当一个对象调用该方法与另一个对象进行比 较,例如obj1.comparTo(obj2),如果该方法返回0,则表明这两个对象相等;如果返回一个正整数,则表明obj1大于obj2;如果该方 法返回一个负整数,则表明obj1小于obj2.
TreeSet的自然排序是根据集合元素的大小,TreeSet将他们以升序排列。如果需要实现定制排序,例如降序,则可以使用Comparator接口。该接口里包含一个int compare(T o1, T o2)方法,该方法用于比较o1和o2的大小。

如果需要实现定制排序,则需要在创建TreeSet集合对象时,并提供一个Comparator对象与该TreeSet集合关联,由该Comparator对象负责集合元素的排序逻辑。

点评

嗯嗯,知道了,谢谢亲~  发表于 2015-10-11 10:37
回复 使用道具 举报 1 0
您需要登录后才可以回帖 登录 | 加入黑马