lambda之map的使用排序

已知一个对象集合,按需求将部分属性抽取出来组成新的集合

 

假设已知的集合为商品详情集合

List<OrderDetail> orderDetailList = orderDTO.getOrderDetailList();

1、组成单列集合 (将商品的id组成一个新的集合)

List<String> productIds = orderDetailList.stream().map(OrderDetail::getProductId).collect(Collectors.toList());

2、组成一个新的对象集合 (将商品id和数量抽取组成CartDTO的集合)

List<CartDTO> cartDTOS = orderDetailList.stream().map(e -> new CartDTO(e.getProductId(), e.getProductQuantity())).collect(Collectors.toList());
 

3、组成新的对象集合 (代码较多,在{}中操作,并return)

toMap的使用

Map<String, String> deptMap = deptList.stream().collect(Collectors.toMap(ManagementDept::getId, ManagementDept::getDName));
Map<String, CheckPlaceConfig> placeConfigMap = checkPlaceConfigs.stream().collect(Collectors.toMap(CheckPlaceConfig::getId, e -> e));

排序

appleList.sort(Comparator.comparing(Apple::getWeight)); // 排序
appleList.sort(Comparator.comparing(Apple::getWeight).reversed()); // 逆序

        appleList.sort(Comparator.comparing(Apple::getWeight)  // 按重量排序
                .reversed() // 逆序
                .thenComparing(Apple::getColor)); // 重量一样按颜色排序

List 转 Map

常用方式

代码如下:

public Map<Long, String> getIdNameMap(List<Account> accounts) {
    return accounts.stream().collect(Collectors.toMap(Account::getId, Account::getUsername));
}

收集成实体本身map

代码如下:

public Map<Long, Account> getIdAccountMap(List<Account> accounts) {
    return accounts.stream().collect(Collectors.toMap(Account::getId, account -> account));
}

account -> account是一个返回本身的lambda表达式,其实还可以使用Function接口中的一个默认方法代替,使整个方法更简洁优雅:

public Map<Long, Account> getIdAccountMap(List<Account> accounts) {
    return accounts.stream().collect(Collectors.toMap(Account::getId, Function.identity()));
}

 分组的方法

Map<Long, List<ActivityUserMissionDO>> map = activityUserMissionDos.stream().collect(Collectors.groupingBy(ActivityUserMissionDO::getParentModuleId));

指定具体收集的map

toMap还有另一个重载方法,可以指定一个Map的具体实现,来收集数据:

public Map<String, Account> getNameAccountMap(List<Account> accounts) {
    return accounts.stream().collect(Collectors.toMap(Account::getUsername, Function.identity(), (key1, key2) -> key2, LinkedHashMap::new));
}
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值