您的位置:

Java List数据筛选

一、List数据筛选方法

Java中的List是一种常用的数据结构,在实际应用中常常需要对List中的数据进行筛选。可以通过下面几种方法实现数据筛选。

1.1 通过循环筛选数据

List<Integer> list = Arrays.asList(1, 2, 3, 4, 5);
List<Integer> result = new ArrayList<>();
for (Integer i : list) {
    if (i % 2 == 0) {
        result.add(i);
    }
}
System.out.println(result);

上述代码通过循环遍历List中的数据,筛选出其中偶数并保存在result变量中,最终输出result列表。这种方法比较容易理解,但是对于大数据量的List来说,效率很低。

1.2 通过Lambda表达式筛选数据

List<Integer> list = Arrays.asList(1, 2, 3, 4, 5);
List<Integer> result = list.stream().filter(x -> x % 2 == 0).collect(Collectors.toList());
System.out.println(result);

上述代码通过使用Lambda表达式和Java 8的Stream API对List中的数据进行筛选。在Lambda表达式中,使用filter方法根据指定的条件过滤出满足条件的元素,最终通过collect方法将符合条件的元素收集到一个新的List中。这种方法比较简洁、高效,推荐使用。

1.3 通过CollectionUtils筛选数据

List<Integer> list = Arrays.asList(1, 2, 3, 4, 5);
List<Integer> result = (List<Integer>) CollectionUtils.select(list, new Predicate<Integer>() {
    @Override
    public boolean evaluate(Integer integer) {
        return integer % 2 == 0;
    }
});
System.out.println(result);

上述代码通过使用Apache Commons Collections中的CollectionUtils工具类对List中的数据进行筛选。可以通过Predicate接口定义筛选条件,将筛选结果保存到新的List中。这种方法比较灵活,但是需要导入第三方库,可能会降低代码可读性。

二、List数据排序方法

在实际应用中,除了需要进行数据筛选之外,还经常需要对数据进行排序。可以使用下面几种方法实现数据排序。

2.1 通过Collections.sort方法排序

List<Integer> list = Arrays.asList(3, 1, 2, 5, 4);
Collections.sort(list);
System.out.println(list);

上述代码通过使用Java标准库中的Collections类对List中的数据进行排序,其中sort方法默认使用自然排序(从小到大)。可以根据具体需求实现自定义比较器。

2.2 通过实现Comparable接口排序

class Student implements Comparable<Student> {
    private int age;

    public int getAge() {
        return age;
    }

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

    @Override
    public int compareTo(Student o) {
        return this.age - o.getAge();
    }
}

List<Student> list = new ArrayList<>();
Student s1 = new Student();
s1.setAge(18);
Student s2 = new Student();
s2.setAge(16);
Student s3 = new Student();
s3.setAge(20);
list.add(s1);
list.add(s2);
list.add(s3);
Collections.sort(list);
System.out.println(list);

上述代码通过实现Comparable接口对自定义类Student中的数据进行排序。在实现Comparable接口时,需要实现compareTo方法,该方法返回一个int值,表示当前对象与参数对象的大小关系。该方法默认实现从小到大排序,也可以根据具体需求实现自定义比较器。

2.3 通过实现Comparator接口排序

class Student {
    private int age;

    public int getAge() {
        return age;
    }

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

List<Student> list = new ArrayList<>();
Student s1 = new Student();
s1.setAge(18);
Student s2 = new Student();
s2.setAge(16);
Student s3 = new Student();
s3.setAge(20);
list.add(s1);
list.add(s2);
list.add(s3);
Collections.sort(list, new Comparator<Student>() {
    @Override
    public int compare(Student o1, Student o2) {
        return o1.getAge() - o2.getAge();
    }
});
System.out.println(list);

上述代码通过实现Comparator接口对自定义类Student中的数据进行排序。在实现Comparator接口时,需要实现compare方法,该方法返回一个int值,表示两个对象的大小关系。与Comparable接口不同的是,该接口的实现可以任意定制,比较灵活,可以根据具体需求实现自定义比较器。