62,635
社区成员




public static <T> void sort(T[] a, Comparator<? super T> c) {
if (c == null) {
sort(a);
} else {
if (LegacyMergeSort.userRequested) //我看到这是永远是true,感觉是进这条分支
legacyMergeSort(a, c);
else
TimSort.sort(a, 0, a.length, c, null, 0, 0);
}
}
private static void mergeSort(Object[] src,
Object[] dest,
int low,
int high,
int off) {
int length = high - low;
// Insertion sort on smallest arrays
if (length < INSERTIONSORT_THRESHOLD) { //列表长度为5 5 < 7 故进这里
for (int i=low; i<high; i++)
for (int j=i; j>low &&
((Comparable) dest[j-1]).compareTo(dest[j])>0; j--)
swap(dest, j, j-1);
return;
}
但输出的过程大相径庭,完全跟我的想法不一样,虽然最后排序结果是降序是对的,但跟我预期的排序过程(冒泡排序)完全不一样
很奇怪,有没大神解释一波