社区
Java SE
帖子详情
TreeSet的排序问题
结贴是美德
2012-01-25 09:28:24
为何称实现Comparable接口这种方式为自然排序?为何Comparator为定制排序?我让元素都实现Comparable接口就不算定制的了? 求解,这两种排序逻辑的实现位置不同,这在选择上有什么特别要注意的么?
...全文
23
2
打赏
收藏
TreeSet的排序问题
为何称实现Comparable接口这种方式为自然排序?为何Comparator为定制排序?我让元素都实现Comparable接口就不算定制的了? 求解,这两种排序逻辑的实现位置不同,这在选择上有什么特别要注意的么?
复制链接
扫一扫
分享
转发到动态
举报
写回复
配置赞助广告
用AI写文章
2 条
回复
切换为时间正序
请发表友善的回复…
发表回复
打赏红包
结贴是美德
2012-01-25
打赏
举报
回复
明白了!!说的很好哈 谢谢这位大哥~~祝节日快乐,接分
爱摸鱼de老邪
2012-01-25
打赏
举报
回复
1.comparable是通用的接口,用户可以实现它来完成自己特定的比较,而comparator可以看成一种算法的实现,在需要容器集合 collection需要比较功能的时候,来指定这个比较器,这可以看出一种设计模式(策略模式Strategy),将算法和数据分离,就像C++ STL中的函数对象一样。
2.前者应该比较固定,和一个具体类相绑定,而后者比较灵活,它可以被用于各个需要比较功能的类使用。可以说前者属于“静态绑定”,而后者可以“动态绑定”。
3.一个类实现了Camparable接口表明这个类的对象之间是可以相互比较的。如果用数学语言描述的话就是这个类的对象组成的集合中存在一个全序。这样,这个类对象组成的集合就可以使用Sort方法排序了。
4.而Comparator的作用有两个:
a,如果类的设计师没有考虑到Compare的问题而没有实现Comparable接口,可以通过Comparator来实现比较算法进行排序
b,可以更加灵活实现排序规则,为了使用不同的排序标准做准备,比如:升序、降序,或者将来想通过类的其他字段进行排序
学生成绩
排序
(
TreeSet
方式实现)
通过
TreeSet
类直接对学生成绩实现了
排序
功能,不必要进行相关额外的
排序
来实现!
解决
TreeSet
类的
排序
问题
本文介绍
TreeSet
支持两种
排序
方法:自然
排序
和定制
排序
。
TreeSet
默认采用自然
排序
。详细请看下
Java集合框架精讲
该课程内容包括:Collection集合的继承体系、Map集合的集合体系、部分数据结构知识点、List、Set、ArrayList、Vector、LinkedList、Iterator(迭代器)、
TreeSet
、HashSet、LinkedHashSet、
TreeSet
、Map、TreeMap、...
浅谈java中的TreeMap
排序
与
TreeSet
排序
下面小编就为大家带来一篇浅谈java中的TreeMap
排序
与
TreeSet
排序
。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
用
TreeSet
,添加字符串,按照长度和字母顺序
排序
用
TreeSet
添加字符串,按照字符串首字母字母顺序和字符串长度顺序
排序
Java SE
62,614
社区成员
307,327
社区内容
发帖
与我相关
我的任务
Java SE
Java 2 Standard Edition
复制链接
扫一扫
分享
社区描述
Java 2 Standard Edition
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
暂无公告
试试用AI创作助手写篇文章吧
+ 用AI写文章