一、正序排序
正序排序是最常见的排序方式,就是按照从小到大的顺序进行排序。下面是一个示例代码:
import java.util.ArrayList; import java.util.Collections; import java.util.List; public class Main { public static void main(String[] args) { Listlist = new ArrayList<>(); list.add(6); list.add(1); list.add(9); list.add(2); list.add(8); Collections.sort(list); System.out.println(list); } }
在上述代码中,我们首先创建了一个List集合,并向其中添加了一些元素。然后通过调用Collections.sort方法对List集合进行排序,最终打印出排序后的结果。
二、倒序排序
除了正序排序,有时候我们还需要进行倒序排序。下面是一个示例代码:
import java.util.ArrayList; import java.util.Collections; import java.util.Comparator; import java.util.List; public class Main { public static void main(String[] args) { Listlist = new ArrayList<>(); list.add(6); list.add(1); list.add(9); list.add(2); list.add(8); Comparator comparator = Collections.reverseOrder(); Collections.sort(list, comparator); System.out.println(list); } }
在上述代码中,我们首先创建了一个List集合,并向其中添加了一些元素。然后通过创建一个倒序的Comparator对象,并将其作为第二个参数传递给sort方法,最终打印出排序后的结果。
三、根据对象属性排序
在实际开发中,我们有时候需要根据一个对象的某个属性进行排序。下面是一个示例代码:
import java.util.ArrayList; import java.util.Collections; import java.util.Comparator; import java.util.List; public class Main { public static void main(String[] args) { Listlist = new ArrayList<>(); list.add(new Student("张三", 18, 90)); list.add(new Student("李四", 19, 80)); list.add(new Student("王五", 17, 95)); list.add(new Student("赵六", 20, 85)); Comparator comparator = Comparator.comparing(Student::getScore); Collections.sort(list, comparator); System.out.println(list); } } class Student { private String name; private int age; private int score; public Student(String name, int age, int score) { this.name = name; this.age = age; this.score = score; } 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 getScore() { return score; } public void setScore(int score) { this.score = score; } @Override public String toString() { return "Student{" + "name='" + name + '\'' + ", age=" + age + ", score=" + score + '}'; } }
在上述代码中,我们首先创建了一个List集合,并向其中添加了一些Student对象。然后通过创建一个根据score属性的Comparator对象,并将其作为第二个参数传递给sort方法,最终打印出排序后的结果。
四、自定义比较器
有时候,我们需要根据复杂的逻辑进行排序,这时候就需要自定义比较器。下面是一个示例代码:
import java.util.ArrayList; import java.util.Collections; import java.util.Comparator; import java.util.List; public class Main { public static void main(String[] args) { Listlist = new ArrayList<>(); list.add(new Student("张三", 18, 90)); list.add(new Student("李四", 19, 80)); list.add(new Student("王五", 17, 95)); list.add(new Student("赵六", 20, 85)); Comparator comparator = new Comparator () { @Override public int compare(Student o1, Student o2) { if (o1.getScore() > o2.getScore()) { return -1; } else if (o1.getScore() < o2.getScore()) { return 1; } else { if (o1.getAge() > o2.getAge()) { return 1; } else if (o1.getAge() < o2.getAge()) { return -1; } else { return 0; } } } }; Collections.sort(list, comparator); System.out.println(list); } } class Student { private String name; private int age; private int score; public Student(String name, int age, int score) { this.name = name; this.age = age; this.score = score; } 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 getScore() { return score; } public void setScore(int score) { this.score = score; } @Override public String toString() { return "Student{" + "name='" + name + '\'' + ", age=" + age + ", score=" + score + '}'; } }
在上述代码中,我们首先创建了一个List集合,并向其中添加了一些Student对象。然后通过创建一个自定义的Comparator对象,并将其作为第二个参数传递给sort方法,最终打印出排序后的结果。
总结
本文介绍了Java中使用list.sort方法对List集合进行排序的示例,并从多个方面对其进行了详细阐述。通过学习本文,读者可以掌握Java中常见的排序方法,为实际开发工作提供帮助。