1.java8 stream().map().collect()的简单使用
List productsList= productsService.findAll(); //从数据库查询商品集合
现在想获取商品的分类ID;在后续的逻辑处理中要用;
常用的方法我们大家都知道,用for循环,
List categoryIdsList=new ArrayList();//定义一个集合来存储商品分类ID
for(int i=0;i<productsList.size();i++){
categoryIdsList.add(productsList.get(i).getCategoryId());
}
这种实现方式过于复杂,java8 API的stream流式处理能一行搞定:
List categoryIdsList= productsList.stream().map(Product::getCategoryId).collect(Collectors.toList())
解释下一这行代码:
productsList:一个实体类的集合,类型为List
Product:实体类
getCategoryId:实体类中的get方法,为获取getCategoryId的categoryId
2.stream流式处理的优势
- 无存储。stream不是一种数据结构,它只是某种数据源的一个视图,数据源可以是一个数组,Java集合容器或I/O channel等。
- 为函数式编程而生。对stream的任何修改都不会修改背后的数据源,比如对stream执行过滤操作并不会删除被过滤的元素,而是会产生一个不包含被过滤元素的新stream。
- 惰式执行。stream上的操作并不会立即执行,只有等到用户真正需要结果的时候才会执行。
- 可消费性。stream只能被“消费”一次,一旦遍历过就会失效,就像容器的迭代器那样,想要再次遍历必须重新生成。