HashMap中的computeIfAbsent() 方法的使用

hashmap.computeIfAbsent(K key, Function remappingFunction)

方法有两个参数:第一个参数是hashMap的key,第二个参数是一个方法,叫做重新映射函数,用于重新计算值(就是说value值是这个方法重新计算后的结果)。

返回值:返回的就是value值

作用:使用这个方法时,如果说key不存在,那么直接把key添加到map中

先看一个简单的实例
如下,创建了一个HashMap为prices。key中没有一个元素为Shirt,使用computeIfAbsent时会先判断有没有一个key为Shirt,如果没有那么把Shirt加到map中,然后value值就是key -> 280这个lamda表达式重新计算的结果,也就是280。所以相当于往map中放入了一个键值对Shirt-280。然后这个方法运行返回的结果就是value,所以shirtPrice值就是280

import java.util.HashMap;

class Main {
    public static void main(String[] args) {
        // 创建一个 HashMap
        HashMap<String, Integer> prices = new HashMap<>();

        // 往HashMap中添加映射项
        prices.put("Shoes", 200);
        prices.put("Bag", 300);
        prices.put("Pant", 150);
        System.out.println("HashMap: " + prices);

        // 计算 Shirt 的值
        int shirtPrice = prices.computeIfAbsent("Shirt", key -> 280);
        System.out.println("Price of Shirt: " + shirtPrice);

        // 输出更新后的HashMap
        System.out.println("Updated HashMap: " + prices);
    }
}

再看一个难一点的。代码如下。

代码前置说明:lineList是一个list列表,包含所有的物料信息(未区分公司),里面存储的是一个个SalePriceLine对象,用来存储物料信息的。SalePriceLine对象中包含一个主要属性ouCode,代表的是公司编码。一个公司下有很多的物料信息,下面这个代码的目的其实就相当于分组,以公司编码分组,找出每个公司对应的所有物料。

代码说明:创建一个HashMap,结构为 Map<ouCode, Map<index, SalePriceLine>> , 将ouCode作为Key,Map<index, SalePriceLine> 作为Value。value中的Integer是用来记录下标的(我项目实现的功能需要记录下标,这里没体现出作用),SalePriceLine是一个对象。

代码解释:先创建一个空的map名为ouLineMap,key用来存储公司编码,value用来存储该公司下的物料信息。 lineList是为分类的所有公司的物料信息。所以去遍历每一条物料信息,调用computeIfAbsent方法,如果ouLineMap的主键中没有该公司,也就是不存在当前ouCode,那么就把当前的ouCode加入到ouLineMap中作为主键,然后value就是直接生成一个最大容量为16的HashMap,然后通过put(i, line),去存放到生成的map中,相当于ouLineMap的value值就是i->line这样的一个键值对,因为computeIfAbsent这个方法返回的就是value值。这样ouCode公司就存放了一条物料信息,然后接着遍历,如果第二次,ouCode已经存在,那么不用加入到map中,直接在value的位置新建一个HashMap,然后把当前的物料信息添加进这个内层的map中。这就是computeIfAbsent的用法,如果不用这个的话就得去用if语句进行判断,那代码就复杂多了。

 Map<String, Map<Integer, SalePriceLine>> ouLineMap = new HashMap<>(ouCodes.size());
        for (int i = 0; i < lineList.size(); i++) {
            SalePriceLine line = lineList.get(i);
            ouLineMap.computeIfAbsent(line.getOuCode(), key -> new HashMap<>(16)).put(i, line);
        }
  • 5
    点赞
  • 25
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值