首先,我们还是需要创建一个Person实体类进行进行我们存储的对象排序里面包含了三个属性name,age,salary。

import java.util.Comparator;
import java.util.Objects;
public class Person{
    private String name;
    private int age;
    //工资
    private int salary;
    @Override
    public String toString() {
        return "Person{" +
                "name='" + name + '\'' +
                ", age=" + age +
                ", salary=" + salary +
                '}';
    }
    @Override
    public boolean equals(Object o) {
        if (this == o) return true;
        if (o == null || getClass() != o.getClass()) return false;
        Person person = (Person) o;
        return age == person.age &&
                salary == person.salary &&
                Objects.equals(name, person.name);
    }
    @Override
    public int hashCode() {
        return Objects.hash(name, age, salary);
    }
    public Person(String name, int age, int salary) {
        this.name = name;
        this.age = age;
        this.salary = salary;
    }
    public Person() {
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public int getAge() {
        return age;
    }
    public void setAge(int age) {
        this.age = age;
    }
    public int getSalary() {
        return salary;
    }
    public void setSalary(int salary) {
        this.salary = salary;
    }
}

在这个实体类中不再需要做其他的修饰。然后进行我们的程序入口main函数:
在这里我们创建了八个对象,有年龄相同的也包含了工资相同的对象,以此来进行排序

import java.util.*;

public class Test {
    public static void main(String[] args) {
        List<Person> list = new ArrayList<>();
        list.add(new Person("张三",14,1200));
        list.add(new Person("李四",21,6500));
        list.add(new Person("王五",18,9000));
        list.add(new Person("王二麻子",21,6000));
        list.add(new Person("刘浩",17,1300));
        list.add(new Person("小七",21,6200));
        list.add(new Person("八哥",18,1300));
        list.add(new Person("玖玖",20,5000));
        for (Person p:list){
            System.out.println(p);
        }
        System.out.println("排序后:");
        Collections.sort(list, Comparator.comparingInt(Person::getAge));
        for (Person p:list){
            System.out.println(p);
        }
    }
}

首先我们第一种玩法,只对我们的年龄按升序排序
核心的代码就是Collections.sort(list, Comparator.comparingInt(Person::getAge)); 我们观察一下运行结果:

Person{name='张三', age=14, salary=1200}
Person{name='李四', age=21, salary=6500}
Person{name='王五', age=18, salary=9000}
Person{name='王二麻子', age=21, salary=6000}
Person{name='刘浩', age=17, salary=1300}
Person{name='小七', age=21, salary=6200}
Person{name='八哥', age=18, salary=1300}
Person{name='玖玖', age=20, salary=5000}
排序后:
Person{name='张三', age=14, salary=1200}
Person{name='刘浩', age=17, salary=1300}
Person{name='王五', age=18, salary=9000}
Person{name='八哥', age=18, salary=1300}
Person{name='玖玖', age=20, salary=5000}
Person{name='李四', age=21, salary=6500}
Person{name='王二麻子', age=21, salary=6000}
Person{name='小七', age=21, salary=6200}

我们可以看到只对年龄进行了排序,如果我们有第二个需求,当我们想要在年龄相同的情况下再对工资salary进行升序排序,那么我们可以在Collections.sort(list, Comparator.comparingInt(Person::getAge));参数范围再添加.thenComparingInt(Person::getSalary)即可实现上述要求。

for (Person p:list){
            System.out.println(p);
        }
        System.out.println("排序后:");
        Collections.sort(list, Comparator.comparingInt(Person::getAge).thenComparingInt(Person::getSalary));
        for (Person p:list){
            System.out.println(p);
        }

然后我们观察一下结果:

Person{name='王二麻子', age=21, salary=6000}
Person{name='小七', age=21, salary=6200}
Person{name='李四', age=21, salary=6500}

可以看见我们实现了此要求。

我们还可以使用下面这种方法进行自定义排序:实体类任然没有改变,Collections.sort()方法参数进行改变:

Collections.sort(list, new Comparator<Person>() {
            @Override
            public int compare(Person o1, Person o2) {
                return o1.getAge()-o2.getAge();
            }
        });

采用这种匿名内部类的形式重写了compare方法 进行了对年龄的升序排序。
如果我们依然想要在年龄相同的情况下按照工资升序排序。那么可以改变方法体里面的内容如下:

public int compare(Person o1, Person o2) {
                if (o1.getAge()-o2.getAge() == 0){
                    return o1.getSalary()-o2.getSalary();
                }
                return o1.getAge()-o2.getAge();
            }

即可实现此要求。
如果我们想要做到降序,那么在方法体里面将o1,o2交换位置即可,同时参数不交换。如下:

public int compare(Person o1, Person o2) {
                if (o2.getAge()-o1.getAge() == 0){
                    return o2.getSalary()-o1.getSalary();
                }
                return o2.getAge()-o1.getAge();
            }

实现了要求。

希望对大家的学习有帮助,这是我总结的Comparator比较器的两种用法。一种就是直接Collections.sort(list,Comparator.comparingInt(Person::getAge))的用法,另外一种进行实现匿名类的方式在参数中new一个Comparator实现compara的重写。参数要注意,与排序升序还是降序有关系。有帮助的话点个赞关注一下喽,有知识错误漏掉的地方欢迎大家指正。

完整代码如下:

//Person类:
package ceshi;

import java.util.Comparator;
import java.util.Objects;

public class Person {
    private String name;
    private int age;
    //工资
    private int salary;

    @Override
    public String toString() {
        return "Person{" +
                "name='" + name + '\'' +
                ", age=" + age +
                ", salary=" + salary +
                '}';
    }

    @Override
    public boolean equals(Object o) {
        if (this == o) return true;
        if (o == null || getClass() != o.getClass()) return false;
        Person person = (Person) o;
        return age == person.age &&
                salary == person.salary &&
                Objects.equals(name, person.name);
    }

    @Override
    public int hashCode() {
        return Objects.hash(name, age, salary);
    }

    public Person(String name, int age, int salary) {
        this.name = name;
        this.age = age;
        this.salary = salary;
    }

    public Person() {
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public int getAge() {
        return age;
    }

    public void setAge(int age) {
        this.age = age;
    }

    public int getSalary() {
        return salary;
    }

    public void setSalary(int salary) {
        this.salary = salary;
    }


}

/**
*main方法  测试类
*/
package ceshi;

import java.util.*;

public class Test {

    public static void main(String[] args) {
        List<Person> list = new ArrayList<>();
        list.add(new Person("张三",14,1200));
        list.add(new Person("李四",21,6500));
        list.add(new Person("王五",18,9000));
        list.add(new Person("王二麻子",21,6000));
        list.add(new Person("刘浩",17,1300));
        list.add(new Person("小七",21,6200));
        list.add(new Person("八哥",18,1300));
        list.add(new Person("玖玖",20,5000));
        for (Person p:list){
            System.out.println(p);
        }
        System.out.println("排序后:");
        Collections.sort(list, new Comparator<Person>() {
            @Override
            public int compare(Person o1, Person o2) {
                if (o2.getAge()-o1.getAge() == 0){
                    return o2.getSalary()-o1.getSalary();
                }
                return o2.getAge()-o1.getAge();
            }
        });
        for (Person p:list){
            System.out.println(p);
        }
    }
}