zoukankan      html  css  js  c++  java
  • Java8中list转map

    第一种: 取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;
    }
  • 相关阅读:
    Codeforces C. Almost Equal (数学规律)
    codeforce D. Shortest Cycle(floyd求最短环)
    Codeforces 1204D2. Kirk and a Binary String (hard version) (dp思路)
    codeforces 1204C Anna, Svyatoslav and Maps(floyd+dp)
    hdu 6214 Smallest Minimum Cut(最小割的最少边数)
    扩展欧几里得求解同余方程(poj 1061)
    poj 3281Dining(网络流 拆点)
    poj 3057(bfs+二分匹配)
    买鱼杂感
    geotrellis使用(十四)导出定制的GeoTiff
  • 原文地址:https://www.cnblogs.com/30go/p/9655780.html
Copyright © 2011-2022 走看看