stream()优点:
1:无存储。stream不是一种数据结构,它只是某种数据源的一个视图,数据源可以是一个数组, Java容器或I/O channel等。
2:为函数式编程而生。对stream的任何修改都不会修改背后的数据源,比如对stream执行过滤操作并不会删除被过滤的元素,而是会产生一个不包含被过滤元素的新stream。
3:惰式执行。stream上的操作并不会立即执行,只有等到用户真正需要结果的时候才会执行。
4:可消费性。stream只能被“消费”一次,一旦遍历过就会失效,就像容器的迭代器那样,想要再次遍历必须重新生成。
List
List<OrderInfoListDto> orderList = orderListInfo.getDataList();
List<CommodityOrderVO> collect=orderList.stream().map(orderInfo->{
CommodityOrderVO orderInfoListVo = new CommodityOrderVO();
BeanUtils.copyProperties(orderInfo, orderInfoListVo);
return orderInfoListVo;
}).collect(Collectors.toList());
Map
Map<Integer, List<String>> map = data.stream().collect(
Collectors.groupingBy(ScTaskDetailVO::getCommunityId,
Collectors.mapping(ScTaskDetailVO::getBuildingNo, Collectors.toList())));
List->map
Map<Long, UserInfo> mapsUserInfo =
list.stream().collect
(Collectors.toMap(UserInfo::getEnterpriseId,
po -> po, (key1, key2) -> key2));