一、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/zh-tw/n/244974.html
微信掃一掃
支付寶掃一掃