compare函数的排序原理

理解compare函数在排序中的应用
compare函数用于比较两个对象,返回值为正、零、负决定是否交换。在升序排序中,返回o1的属性值减去o2的属性值,反之则用于降序。对于String,从首字符的ASCII值开始比较,不同则返回差值,相同则比较长度。

之前一直不太理解compare函数的排序原理,主要是没搞清楚返回1和-1时是要交换还是不交换,今天记录一下。

Compare

样例代码:

class SortDemo extends Ordering[((Any, String), Int)]{
  override def compare(x: ((Any, String), Int), y: ((Any, String), Int)): Int = {
    y._2 - x._2
  }
}

原理:

  1. compare返回值是Int类型,三种情况正数、0、负数。
  2. compare如果比较的是Int、Float、Double类型的话,直接以值进行比较。
  3. compare如果比较的是String、char类型的数据,它会从两个数据的第一个字符开始比较,如果不同,就返回两个字符的ASCII差值;如果字符都相同,那么再比较两个字符串的长度,最后返回两个字符串长度的差值。
  4. compare比较如果返回的是正数,那么两个数要进行交换,如果结果为负数和0,两个数都不会进行交换

结论:

对于compare(Object o1,Object o2)而言,

  • 如果要按照对象的某一个属性进行升序排序,那么直接返回o1(.属性值)-o2.(属性值)(因为如果第一个数比第二个数大,会返回正值,两个对象要进行交换)。
  • 如果要按照对象的某一个属性进行降序排序,那么直接返回o2(.属性值)-o1(.属性值)(因为如果第二个数比第一个数大,会返回正值,两个对象要进行交换)。

参考链接:https://blog.csdn.net/BLACKLOVE7/article/details/114263808

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

打孔猿

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

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

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

打赏作者

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

抵扣说明:

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

余额充值