栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

Collection类的sort()方法如何调用Comparable的compareTo()?

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Collection类的sort()方法如何调用Comparable的compareTo()?

请参阅开放的jdk源代码。我想这会有所帮助。

java.util.Collections:

132     public static <T extends Comparable<? super T>> void More     ...sort(List<T> list) {133         Object[] a = list.toArray();134         Arrays.sort(a);135         ListIterator<T> i = list.listIterator();136         for (int j=0; j<a.length; j++) {137  i.next();138  i.set((T)a[j]);139         }140     }

集合排序调用Arrays.sort

java.util.Arrays:

1218    public static <T> void More ...sort(T[] a, Comparator<? super T> c)   {1219        T[] aux = (T[])a.clone();1220        if (c==null)1221 mergeSort(aux, a, 0, a.length, 0);1222        else1223 mergeSort(aux, a, 0, a.length, 0, c);1224    }

Arrays.sort调用Arrays.mergeSort,您的答案在第1157行。

11451146    private static void More ...mergeSort(Object[] src,1147 Object[] dest,1148 int low,1149 int high,1150 int off) {1151        int length = high - low;11521153        // Insertion sort on smallest arrays1154        if (length < INSERTIONSORT_THRESHOLD) {1155 for (int i=low; i<high; i++)1156     for (int j=i; j>low &&1157   ((Comparable) dest[j-1]).compareTo(dest[j])>0; j--)1158         swap(dest, j, j-1);1159 return;1160        }11611162        // Recursively sort halves of dest into src1163        int destLow  = low;1164        int destHigh = high;1165        low  += off;1166        high += off;1167        int mid = (low + high) >>> 1;1168        mergeSort(dest, src, low, mid, -off);1169        mergeSort(dest, src, mid, high, -off);11701171        // If list is already sorted, just copy from src to dest.  This is an1172        // optimization that results in faster sorts for nearly ordered lists.1173        if (((Comparable)src[mid-1]).compareTo(src[mid]) <= 0) {1174 System.arraycopy(src, low, dest, destLow, length);1175 return;1176        }11771178        // Merge sorted halves (now in src) into dest1179        for(int i = destLow, p = low, q = mid; i < destHigh; i++) {1180 if (q >= high || p < mid && ((Comparable)src[p]).compareTo(src[q])<=0)1181     dest[i] = src[p++];1182 else1183     dest[i] = src[q++];1184        }1185    }


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/495040.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号