Collections与Arrays的排序
来源:互联网 发布:留学机构 知乎 编辑:程序博客网 时间:2024/06/05 17:48
Collections的排序是通过sort方法实现的如下:
public static <T extends Comparable<? super T>> void sort(List<T> list)
jdk1.7的源码中是通过Arrays.sort(list.toArray())对list进行排序的。
public static <T extends Comparable<? super T>> void sort(List<T> list) { Object[] a = list.toArray(); Arrays.sort(a); ListIterator<T> i = list.listIterator(); for (int j=0; j<a.length; j++) { i.next(); i.set((T)a[j]); } }
Arrays.sort()是对数组进行排序的,如果是基本类型的话就是对基本类型进行升序进行快速排序。而数组中的元素是对象的话,是通过元素的自然顺序对对象数组按升序进行排序 。
自然排序是指实现了Comparable接口,并实现了compareTo()方法,比较此对象与指定对象的顺序。如果该对象小于、等于或大于指定对象,则分别返回负整数、零或正整数。
以String方法为例:
public int compareTo(String anotherString) { int len1 = value.length; int len2 = anotherString.value.length; int lim = Math.min(len1, len2); char v1[] = value; char v2[] = anotherString.value; int k = 0; while (k < lim) { char c1 = v1[k]; char c2 = v2[k];
//按顺序比较字符,如果不同返回其ASCLL差值 if (c1 != c2) { return c1 - c2; } k++; }
//如果前lim位相同,则返回其长度差值 return len1 - len2; }
1 0
- Collections与Arrays的排序
- Collections,Arrays的排序功能
- Java中Collections与Arrays的排序解析
- Arrays 和 Collections 排序
- Java Collections与Arrays的浅解
- 利用Collator和Collections.sort对list进行中文排序,注意与Arrays.sort的区别
- Collections与Arrays
- java Collections Arrays ArrayList 类的运用 进行对象排序
- Collection与Collections,Array与Arrays的区别
- Collection与Collections,Array与Arrays的区别
- Collection与Collections,Array与Arrays的区别
- Collection与Collections,Array与Arrays的区别
- 黑马程序员--Collections与Arrays
- Collections与Arrays工具类
- Collection 和 Collections;Array与Arrays的区别
- Collection 和 Collections;Array与Arrays的区别
- 用 Arrays 和 Collections 完成高效排序
- 用 Arrays 和 Collections 完成高效排序
- syskey (win7启动密码)加密和破解方法
- TCP的拥塞控制
- Shoot to kill; CSS selector intent
- mysql 插入语句 删除语句
- 软件项目版本号的命名规则及格式
- Collections与Arrays的排序
- c#通过http协议连接php
- HOW TO: Find the Problem Exception Stack When You Receive an UnhandledExceptionFilter Call in the St
- c++ 读取txt文件
- UVA - 310 L--system(bfs+hash)
- 应用在tomcat上的部署以及将免安装的tomcat配置成服务自启动
- opencv中的绝对路径问题
- 指针数组 数组指针
- iOS开发 证书相关信息汇总