一、sort方法排序
對於List集合,Java提供了Collections類的sort靜態方法,可以直接對List進行排序,排序後的結果覆蓋原來的List。
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
public class SortList {
public static void main(String[] args) {
List<Integer> list = new ArrayList<>();
list.add(3);
list.add(1);
list.add(5);
list.add(2);
Collections.sort(list);
System.out.println(list);//[1, 2, 3, 5]
}
}
sort方法默認按照自然排序進行排序,如果要自定義排序方式,可以實現Comparator接口並傳入sort方法。
import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;
class Student {
private String name;
private int age;
public Student(String name, int age) {
this.name = name;
this.age = age;
}
public String getName() {
return name;
}
public int getAge() {
return age;
}
@Override
public String toString() {
return "Student{" +
"name='" + name + '\'' +
", age=" + age +
'}';
}
}
public class SortListWithComparator {
public static void main(String[] args) {
List<Student> list = new ArrayList<>();
list.add(new Student("Tom", 20));
list.add(new Student("Lucy", 19));
list.add(new Student("Jan", 22));
list.add(new Student("David", 18));
Collections.sort(list, new Comparator<Student>() {
@Override
public int compare(Student o1, Student o2) {
return o1.getAge() - o2.getAge();
}
});
System.out.println(list);//[Student{name='David', age=18}, Student{name='Lucy', age=19}, Student{name='Tom', age=20}, Student{name='Jan', age=22}]
}
}
二、自然排序
如果List中的元素是Comparable接口的實現類,可以直接使用Collections.sort方法進行排序。
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
class Person implements Comparable<Person> {
private String name;
private int age;
public Person(String name, int age) {
this.name = name;
this.age = age;
}
public String getName() {
return name;
}
public int getAge() {
return age;
}
@Override
public int compareTo(Person o) {
return this.age - o.age;
}
@Override
public String toString() {
return "Person{" +
"name='" + name + '\'' +
", age=" + age +
'}';
}
}
public class SortListWithComparable {
public static void main(String[] args) {
List<Person> list = new ArrayList<>();
list.add(new Person("Tom", 20));
list.add(new Person("Lucy", 19));
list.add(new Person("Jan", 22));
list.add(new Person("David", 18));
Collections.sort(list);
System.out.println(list);//[Person{name='David', age=18}, Person{name='Lucy', age=19}, Person{name='Tom', age=20}, Person{name='Jan', age=22}]
}
}
三、流式排序
Java8中加入了Stream API,可以使用stream方法對List進行排序。
import java.util.ArrayList;
import java.util.Comparator;
import java.util.List;
class Fruit {
private String name;
private int price;
public Fruit(String name, int price) {
this.name = name;
this.price = price;
}
public String getName() {
return name;
}
public int getPrice() {
return price;
}
@Override
public String toString() {
return "Fruit{" +
"name='" + name + '\'' +
", price=" + price +
'}';
}
}
public class SortListWithStream {
public static void main(String[] args) {
List<Fruit> list = new ArrayList<>();
list.add(new Fruit("apple", 5));
list.add(new Fruit("banana", 3));
list.add(new Fruit("watermelon", 10));
list.add(new Fruit("pear", 4));
List<Fruit> sortedList = list.stream()
.sorted(Comparator.comparing(Fruit::getPrice))
.toList();
System.out.println(sortedList);//[Fruit{name='banana', price=3}, Fruit{name='pear', price=4}, Fruit{name='apple', price=5}, Fruit{name='watermelon', price=10}]
}
}
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hk/n/244859.html