Java Comparator比较器

  • Post author:
  • Post category:java




Java 对象自定义排序

实现对集合中元素的排序,这个元素可以是一个对象。

两种方式:

  • Comparable:内部比较器
  • Comparator:外部比较器



1. Comparable,内部比较器

  • 写在排序对象的内部
  • 排序接口
  • 一个实现了该接口的类,可以通过如下方法排序

    • Collections.sort
    • Arrays.sort
  • 该接口只有一个compareTo方法
class Person implements Comparable<Person>{
	private int age;
    private String name;
	...
	
	@Override
	public int compareTo(Person person) {
		// 升序排列
		return this.getAge()-person.getAge();;
	}
}



2. Comparator,外部比较器

  • 匿名内部类的方式,在list需要排序的时候,才具体定义排序的规则。

  • 在java中,如果要对集合对象或数组对象进行排序,需要实现Comparator接口。

   //Lambda简化Comparator接口匿名内部类写法

    public static void main(String[] args) {

        List<Student> ls = new ArrayList<>();
        Student s1 = new Student("小明",25);
        Student s2 = new Student("小黑",23);
        Student s3 = new Student("小红",22);
        Collections.addAll(ls,s1,s2,s3); //collections工具类

        //按年龄排序
        Collections.sort(ls, new Comparator<Student>() {
            @Override
            public int compare(Student o1, Student o2) {
            	// 升序
                return o1.getAge() -o2.getAge();
            }
        });
        System.out.println(ls);//[Student{name='小红', age=22}, Student{name='小黑', age=23}, Student{name='小明', age=25}]

        //使用lambda简化
        Collections.sort(ls,(Student o3, Student o4) ->{
            return o3.getAge()-o4.getAge();
        });
        System.out.println(ls);

    }




版权声明:本文为u010868192原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。