自然排序Comparable的使用


一、例题

在这里插入图片描述

按照TreeSet()根据元素的自然排序进行排序:

在这里插入图片描述
这样写不但没有按照要求排序而且抛出了异常

在这里插入图片描述
如果要进行自然排序就要对这个类实现Comparable接口

因为学生类并没有实现这个接口,所以报错了

接下来实现Comparable接口:

在这里插入图片描述
实现这个接口并重写compareTo方法
返回值是0,先不改看一下是什么情况

在这里插入图片描述
不报错,但是只存储了一个对象

二、原因分析

第一个元素存储时是不需要和别人比较的,所以存储成功
第二个元素是需 要和别人比较的,他会按照给的排序规则进行比较

我们的规则反的是一个0,如果反的是0,他会认为s2和s1是同一个元素,所以没有添加成功,同理s2和s4也没有添加成功

改成
在这里插入图片描述
在这里插入图片描述
s2和s1比反的是一个正数,他就认为s2比s1大,所以s2存在了s1后边同理。。。。
顺序输出

return-1就会倒着输出

所以重写方法应该按要求写

在这里插入图片描述
因为s1不用做比较,所以是从s2开始,相当于s2调用这个方法并把上一个s1当做参数传进来,谁调用方法this就是谁,那么实际上s就是s1,this就是s2

在这里插入图片描述
这时按照年龄排序,如果再输入姓名不同但是年龄相同的人就会识别为重复,无法添加

我们需要采取以下措施:
将compare To方法重写为:

都和s1作比较,按照差值进行了排序
在这里插入图片描述
这样就实现了先按年龄排序,年龄相同按姓名排序

name直接调用compareTo方法是因为字符串本身就实现了Comparable接口

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

诸葛东_

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值