一、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接口不同的是,该接口的实现可以任意定制,比较灵活,可以根据具体需求实现自定义比较器。
原创文章,作者:小蓝,如若转载,请注明出处:https://www.506064.com/n/244974.html
微信扫一扫
支付宝扫一扫