JDK1.8之后,List新增了sort方法,使用Comparator作为参数,调用者可自定义比较规则。
User user1 = new User(12, "张三");
User user2 = new User(10, "李四");
User user3 = new User(13, "王五");
User user4 = new User(9, "小六");
List<User> list = new ArrayList<>();
list.add(user1);
list.add(user2);
list.add(user3);
list.add(user4);
System.out.println(Arrays.toString(list.toArray()));
list.sort(new Comparator<User>() {
@Override
public int compare(User o1, User o2) {
//比较byte,short, int型
//return o1.getAge().compareTo(o2.getAge());
//compareTo()方法在对字符串进行比较时,比较的是Unicode码,并不能对汉字进行准确的排序,所以汉字比较时会出现比较混乱的结果。
//对于英文字符,是比较的ASCII码,得出的结果是正常的
//return o1.getName().compareTo(o2.getName()); //结果不正确
//解决方案:重写compare方法
Collator instance = Collator.getInstance(Locale.CHINA);
return instance.compare(o1.getName(), o2.getName());
//return o1.getName().compareTo(o2.getName());
}
});
System.out.println(Arrays.toString(list.toArray()));
需要注意的是,如果比较中文是使用的Unicode编码,此时,比较结果就会就会出现混乱,但Java也提供了解决方案。上面代码已经给出。
按照名称排序:
Integer 比较
String中compareTo方法源码:
现以最小的字符串长度循环比较该位置字符的ASCII码的值,若不相等,返回差值;如果相等,返回两个String长度的差值。
List中sort()方法源码:
在看这段源码的过程中,又发现了一个知识点,就是default修饰符,default修饰符类似于C++中的虚函数,在接口中,使用该修饰符的方法可以方法体。
注意一点:基本上所有实现Comparable的java核心类都具有与equals一致的自然排序,但是java.math.BigDecimal例外,他的自然排序将值相等但精度不等的BigDecimal对象(如1.0和1.00)视为相等。
运行结果为:
false
0