Java8 Map中的computeIfAbsent方法

本文详细探讨了Java集合框架中Map接口的computeIfAbsent方法的使用,该方法首先尝试通过key从Map中获取值,若不存在则调用提供的函数生成新值并存入Map。示例代码展示了如何利用此方法动态生成和更新Map内容,特别是在处理复杂数据结构时的高效应用。此外,还提供了一个实际的复杂用法示例,展示了如何根据特定条件获取和构建多层嵌套Map。
摘要由CSDN通过智能技术生成

computeIfAbsent 使用

源码解析

两 个 参 数 K k e y , F u n c t i o n < ? s u p e r K , ? e x t e n d s V > m a p p i n g F u n c t i o n 也 就 是 : 首 先 使 用 m a p . g e t ( k e y ) , 如 果 存 在 则 返 回 。 \color{red}两个参数 K key, Function<? super K, ? extends V> mappingFunction 也就是:首先使用map.get(key),如果存在则返回。 Kkey,Function<?superK,?extendsV>mappingFunction使map.get(key)
如 果 不 存 在 , 则 调 用 第 二 个 函 数 , 产 生 一 个 对 象 返 回 \color{red}如果不存在,则调用第二个函数,产生一个对象返回
注 意 这 里 还 会 将 对 象 塞 入 到 m a p 中 \color{red}注意这里还会将对象塞入到map中 map
在这里插入图片描述
类似代码:

 @Test
    public void test1() {
        Map<String, String> map = Maps.newHashMapWithExpectedSize(16);
        String a = map.get("a");
        if (StringUtils.isBlank(a)) {
            a = "a没有值,手动赋值";
        }

        String b = map.computeIfAbsent("b", x -> "b也是没有值,手动出去一个");

        System.out.println(a);
        System.out.println(b);
    }

在这里插入图片描述

复杂用法

/**
	 * 根据pspuId获取未来时间的最小最大购买件数map
	 * @param prodSpuIdSet            pSpuIdSet
	 * @param previewPriceTimes        预告价取价时间对应获取未来的最小最大购买件数
	 * @return key是ProdSpuI; value: key 时间格式为 yyyy-MM-dd HH:mm:ss 的未来时间, value 最小最大购买件数vo
	 */
	private Map<String, Map<Long, ProdSpuCurrentMinMax>> getPreviewProdSpuCurrentMinMaxMap(Set<String> prodSpuIdSet,
			List<Date> previewPriceTimes) {
		Map<String, Map<Long, ProdSpuCurrentMinMax>> previewMinMaxMap = Maps
				.newHashMapWithExpectedSize(prodSpuIdSet.size());
		if (CollectionUtil.isNotEmpty(prodSpuIdSet)) {
			previewPriceTimes.forEach(previewPriceTime -> {
				Map<String, ProdSpuCurrentMinMax> minMax = XXXXXXX.INSTANCE
						.getProdSpuCurrentMinMax(Lists.newArrayList(prodSpuIdSet), previewPriceTime.getTime());

				minMax.forEach((k, v) -> previewMinMaxMap.computeIfAbsent(k, a -> Maps.newHashMapWithExpectedSize(3))
						.put(previewPriceTime.getTime(), v));
			});
		}
		log.info(LogMsgKit.of("getPreviewProdSpuCurrentMinMaxMap").p("previewMinMaxMap", previewMinMaxMap)
				.end("获取预告价取价时间的起购件数!"));
		return previewMinMaxMap;
	}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值