首先,我们还是需要创建一个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);
}
}
}