java8 函数式编程 新特性集合封装

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));
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章