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;
    }
  • 相关阅读:
    leetcode-442-数组中重复的数据
    leetcode-83-删除排序链表中的重复元素
    leetcode-80-删除排序数组中的重复项 II
    leetcode-26-删除排序数组中的重复项
    leetcode-889-105-106-根据前-中-后遍历构造二叉树
    leetcode-88-合并两个有序数组
    凉了!张三同学没答好「进程间通信」,被面试官挂了....
    多线程为了同个资源打起架来了,该如何让他们安定?
    Xlua中LuaBehaviour的实现
    Elasticsearch实战一
  • 原文地址:https://www.cnblogs.com/30go/p/9655780.html
Copyright © 2011-2022 走看看