来自小白的Arrays.sort()底层探秘

来自小白的Arrays.sort()底层探秘

刷leetcode的时候我们经常会用到Arrays这个工具类的sort()方法来给我们的数组排序,这个方法默认是从小到大排序的,我们需要从大到小排序的话需要自定义一个Comparator对象来实现这一功能。那么它底层到底是怎么来实现的呢?
首先,Arrays.sort()只有一个数组引用作为参数的时候,也就是默认升序排列的时候,底层是一个DualPivotQuickSort()方法,这个方法只看名字会让人想到是不是应用快排来处理的。
不要急,让我们继续看。进入该方法以后可以看到它其实集快排,归并,插入,计数四种排序于一身。快排归并插入三种排序是基于比较的排序,基于比较的排序最好的时间复杂度是O(nlogn),插入排序是把元素放入桶中排序,是牺牲空间换取时间的排序方法,虽然空间开销较大,但是可以换取时间性能。
在DualPivotQuickSort()方法中定义了一些阈值,
当长度小于47时,数组属于小数组的范畴,那么插入排序的性能优于快排;
当长度小于286时,快排的性能优于归并排序。
内部逻辑中首先判断数组长度是否小于286,小于则调用sort()方法(这里包括快排和插入两种,有后续判断数组长度是否小于47来决定采用插入还是快排),
大于则首先判断该数组是否已经基本有序,如果不是有序的的话则在破坏递增或递减性的第一个元素处启用快排使数组有序;
数组原本就已经基本有序了的话就启用归并排序,首先为归并做准备,开一个数组work以及一个引用b(指向原本的数组a),用System.arraycopy()方法把a拷贝到work中,b指向a,a指向work(通俗点讲其实就是work是一个辅助空间,把a拷贝一份给b)。然后在b上使用归并排序后传给a。
此外,之前提到的计数排序,当待排序的是个长度大于29的byte数组时,会采用计数排序代替插入排序,当待排序的是一个长度大于3200的short或char数组的时候,会使用计数排序代替快排。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值