有了stream流式计算,结合着函数式接口和链式调用,对于数据的处理变得更加简单,同时增强可读性。
比如我们有一个User类:
@Data
@AllArgsConstructor
@NoArgsConstructor
public class User {
private int id;
private String name;
private int age;
}
然后有一些User对象:
User user1 = new User(1,"a",12);
User user2 = new User(2,"b",32);
User user3 = new User(3,"C",15);
User user4 = new User(4,"D",21);
User user5 = new User(5,"e",29);
我们有这么一些要求:
/**
* 按要求找到并操作以下user
* 1,年龄为奇数
* 2,名字为大写
* 将大写转为小写
* 并按名字倒序排序
* 并取出第一个
*/
要找到年龄为奇数并且名字为大写的User只要用过滤器就行了。
结果应该是
User user3 = new User(3,"C",15);
User user4 = new User(4,"D",21);
这两位。
然后要将名字从大写改为小写,就是调用toLowerCase()
。
顺序应该是c d
,倒序就是d c
。调用Comparator
的reverseOrder
方法即可。
只取一个值,那就是d
了。
我们要的结果就是d
。
代码:
users.stream().filter(u-> u.getAge()%2==1).
filter(u-> u.getName().matches("[A-Z]")).
map(u->u.getName().toLowerCase())
.sorted(Comparator.reverseOrder())
.limit(1)
.forEach(System.out::println);
filter里面要传Predicate
,map里传Function
,sorted里传Comparator
,forEach要传一个Consumer
。这四个接口都是函数式接口,抽象方法都只有一个。