菜单 学习猿地 - LMONKEY

VIP

开通学习猿地VIP

尊享10项VIP特权 持续新增

知识通关挑战

打卡带练!告别无效练习

接私单赚外块

VIP优先接,累计金额超百万

学习猿地私房课免费学

大厂实战课仅对VIP开放

你的一对一导师

每月可免费咨询大牛30次

领取更多软件工程师实用特权

入驻
208
0

Java8中list转map

原创
05/13 14:22
阅读数 78643

第一种: 取list中某2个字段作为Map的K,V

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

 

第二种:将id和实体Bean做为K,V

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

或者这样写:

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

account -> account是一个返回本身的lambda表达式,后面的使用Function接口中的一个默认方法代替,使整个方法更简洁优雅。

第三种: key存在重复记录时处理

public Map<String, Account> getNameAccountMap(List<Account> accounts) {
    return accounts.stream().collect(Collectors.toMap(Account::getUsername, Function.identity(), (key1, key2) -> key2));
}

如果使用第一种方法会出错,所以这里只是简单的使用后者覆盖前者来解决key重复问题。

第四种: 使用某个具体的Map类来保存,如保存时使用LinkedHashMap

public Map<String, Account> getNameAccountMap(List<Account> accounts) {
    return accounts.stream().collect(Collectors.toMap(Account::getUsername, Function.identity(), (key1, key2) -> key2, LinkedHashMap::new));
}

 

第五种: List<Object>转List<String,Map<String, String>>

类似采购订单 id,对应明细记录。

public Map<String,List<MCode>> getCodeListMap(){
        if(CollectionUtils.isEmpty(codeListMap)){
                List<MCode> codeList = this.getCodeList();
                Set<String> keySet = codeList.stream().map(code -> code.getCodeKbn()).collect(Collectors.toSet());
                Iterator<String> it = keySet.iterator();
                while(it.hasNext()) {
                        String key = it.next();
                        codeListMap.put(key, codeList.stream().filter(code -> code.getCodeKbn().equals(key)).collect(Collectors.toList()));
                }
        }
        return codeListMap;
}

 

发表评论

0/200
208 点赞
0 评论
收藏