Java8collection.sort_Collections.sort()源码分析(基于JAVA8)

java.lang.Object java.util.Collections简介

此类仅包含操作或返回集合的静态方法。

它包含多样的对集合进行操作的算法,“包装器”,返回由指定集合支持的新集合,以及其他一些细碎功能。

如果提供给它们的集合或类对象为null,则此类的方法都抛出NullPointerException

该类中包含的多态算法的文档通常包括实现的简要说明 。 这些描述应被视为实现说明 ,而不是说明的一部分 。 只要规范本身得到遵守,实现者就可以随意替代其算法。 (例如,sort使用的算法不一定是一个mergesort,但它必须是稳定的 算法)

如果集合不支持适当的突变原语,例如set方法,则该类中包含的“破坏性”算法,即修改其操作的集合的算法被指定为抛出UnsupportedOperationException。 如果调用对集合没有影响,这些算法可能但不是必须抛出此异常。 例如,在已经排序的不可修改列表上调用sort方法可以抛出UnsupportedOperationException

Collections的sort方法代码:

AAffA0nNPuCLAAAAAElFTkSuQmCC

AAffA0nNPuCLAAAAAElFTkSuQmCC

> 表示该方法中传递的泛型参数必须实现了Comparable中的compareTo(T o)方法,否则进行不了sort排序

其sort方法实现都委托给了java.util.List接口的默认实现的sort方法

AAffA0nNPuCLAAAAAElFTkSuQmCC

方法细节奏:

(1)将list转换成一个Object数组

(2)将这个Object数组传递给Arrays类的sort方法(也就是说Collections的sort本质是调用了Arrays.sort)

(3)完成排序之后,再一个一个地,把Arrays的元素复制到List中

AAffA0nNPuCLAAAAAElFTkSuQmCC

注意到sort有一个条件判断,当LegacyMergeSort.userRequested==true,采用legacyMergeSort

否则采用ComparableTimSort

LegacyMergeSort.userRequested的字面意思大概就是“用户请求传统归并排序”,这个分支调用的是与jdk5相同的方法来实现功能。

ComparableTimSort是改进后的归并排序,对归并排序在已经反向排好序的输入时表现为O(n^2)的特点做了特别优化。对已经正向排好序的输入减少回溯。对两种情况(一会升序,一会降序)的输入处理比较好(摘自百度百科)。legacyMergeSort代码:

AAffA0nNPuCLAAAAAElFTkSuQmCC

泛型版

mergeSort代码

AAffA0nNPuCLAAAAAElFTkSuQmCC

①:对dest[]排序,传递过来的List list也就排好了序,src[]数组用做中介,即后面的方法需要调用,这里有个判断条件为length < INSERTIONSORT_THRESHOLD

INSERTIONSORT_THRESHOLD为Arrays的一个常量7,它定义了如果数组元素小于7用插入排序

②:当数组元素不小于7,

先将数组拆分成低区间和高区间

再调用两个递归对区间元素排序。在递归时注意还会判断已划分区间元素是否还不少于7,如果不小于7继续划分成两个区间,这样循环递归调用

特别注意src[]和dest[]的参数位置,调用递归时,是将src[]数组作为排序对象进行排序,src[]排序后,在通过③或④方法将dest[]数组依据src进行排序。最终达到List list排序的结果。

③:如果初始元素个数不小于7进过②方法后,只有两种情况:两个排好序的低区间和高区间。这个方法作用是:如果低区间列表中的最高元素小于高区间列表中的最低元素,则表明该次递归循环的区间段已经排好序,然后将这段数据复制到dest[]数组中。

反之则进入方法④

④:进入该方法表明该次递归循环的左区间最大元素大于右区间最小元素,也就是说左区间的数组元素值都大于高区间的数组元素值,因此将src中的高区间元素和低区间元素调换放入dest数组中。这样一次递归循环就调用完毕,如果还有循环就继续排序下去,否则排序就已经完成。

TimSort.sort()/*

* The next method (package private and static) constitutes the

* entire API of this class.

*/

/**

* Sorts the given range, using the given workspace array slice

* for temp storage when possible. This method is designed to be

* invoked from public methods (in class Arrays) after performing

* any necessary array bounds checks and expanding parameters into

* the required forms.

*

* @param a the array to be sorted

* @param lo the index of the first element, inclusive, to be sorted

* @param hi the index of the last element, exclusive, to be sorted

* 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值