什么是Stream流计算
大数据:存储+计算
集合、Mysql本质是存储东西的。
计算都应该交给流来操作。
示例:
/**
* 现有5个用户,筛选:
* 1. ID偶数的
* 2. 年纪大于23岁
* 3. 用户名转为大写字母
* 4. 用户名字母倒排序
* 5. 只输出一个用户
*/
public class Test {
public static void main(String[] args) {
User u1 = new User(1, "a", 21);
User u2 = new User(2, "b", 22);
User u3 = new User(3, "c", 23);
User u4 = new User(4, "d", 24);
User u5 = new User(5, "e", 25);
// 集合用于存储
List<User> list = Arrays.asList(u1, u2, u3, u4, u5);
//计算交给Stream流
// filter:筛选
// map:转化
// sorted:排序
// limit:分页
list.stream()
.filter(u -> {return u.getId()%2 == 0;})
.filter(u -> {return u.getAge() > 23})
.map(u -> {return u.getName().toUpperCase();})
.sorted((uu1, uu2) -> {return uu1.compareTo(uu2);})
.limit(1)
.forEach(System.out::println);
}
}