zoukankan      html  css  js  c++  java
  • 使用java8将list转为map

    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));
    }

    //key由多个属性组成
    Map<String, SalesPurchaseDailyStatistics> existStatisticsMap = existStatisticsList.stream().collect(Collectors.toMap(item -> item.getStatisticsDay() + "_" + item.getUserName(), Function.identity()));

    Key作类型转换

    Map<String, TOwpAmazon> tOwpAmazonMap = tOwpAmazonList.stream().collect(Collectors.toMap(item -> item.getId().toString(), Function.identity()));

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

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

    重复key的情况

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

     这个方法可能报错(java.lang.IllegalStateException: Duplicate key),因为name是有可能重复的。toMap有个重载方法,可以传入一个合并的函数来解决key冲突问题:

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

    这里只是简单的使用后者覆盖前者来解决key重复问题。还有一种分组的方法:

    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));
    }
    

     分组

    Map<Integer, List<PyTradeOrderDt>> orderMap = pyTradeOrderDts.stream().collect(Collectors.groupingBy(PyTradeOrderDt::getTradeNid));
    
    orderMap.forEach((k, v) -> {
        Set<String> collect = v.stream().map(PyTradeOrderDt::getSku).collect(Collectors.toSet());
        skuSet.addAll(collect);
    });

    //按多个属性分组
    Map<String, List<JsonObject>> menuGroupMap = list.stream().collect(Collectors.groupingBy(goods -> goods.getInteger("menu_id")+"_"+goods.getString("menu_name")));

    List常用方式  

    List<String> nidList = resultList.stream().map(TrackNoOverTimeDto::getNid).collect(Collectors.toist());
    //String类型转Int
    List<Integer> nidIntList = nidList.stream().map(Integer::parseInt).collect(Collectors.toList());

     

    List排序

     List<TrackNoOverTimeDto> resultList = new ArrayList<>();
     
     resultList.forEach(item ->{
        List<PyTradeLogs> pyTradeLogs = collect.get(item.getNid());
    
        //取出日志ID最大的记录
        PyTradeLogs tradeLogs = pyTradeLogs.stream().sorted((s1, s2) -> {
            if (s1.getOpDate() != null && s2.getOpDate() != null) {
                //如果日期都有值,按日期排序
                return -s1.getOpDate().compareTo(s2.getOpDate());
            } else if (s1.getOpDate() == null && s2.getOpDate() == null) {
                //如果日期都没有值,按主键ID排序
                return -s1.getNID().compareTo(s2.getNID());
            } else if (s1.getOpDate() == null && s2.getOpDate() != null) {
                //opDate为null的放在最后
                return 1;
            } else if (s1.getOpDate() != null && s2.getOpDate() == null) {
                //opDate为null的放在最后
                return -1;
            }
            return -s1.getNID().compareTo(s2.getNID());
        }).findFirst().get();
    });
  • 相关阅读:
    LA 6439 Pasti Pas! Hash
    HDU 1067 Gap BFS+Hash
    POJ 3474 Gold Balanced Lineup Hash
    ZOJ 3802 Easy 2048 Again 状压DP
    Hihocoder #1044 状态压缩·一
    HDU 2522 & AOJ 441 & AOJ 364 关于小数和分数的转换
    HDU 2549 Sumset Hash+枚举
    POJ 1840 Eqs Hash + 中途相遇法
    HDU 2128 Tempter of the Bone II BFS
    POJ 3686 & 拆点&KM
  • 原文地址:https://www.cnblogs.com/weslie/p/14860305.html
Copyright © 2011-2022 走看看