ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

JDK8中Map.computeIfPresent() 方法的使用

2021-12-06 14:07:35  阅读:209  来源: 互联网

标签:Map return HashMap param JDK8 key appId computeIfPresent


Map.computeIfPresent() 方法的使用

一.简介

JDK8中新增了Map.computeIfPresent()方法,computeIfPresent() 方法对 hashMap 中指定 key 的值进行重新计算,前提是该 key 存在于 hashMap 中。

computeIfPresent() 方法的语法为:

hashmap.computeIfPresent(K key, BiFunction remappingFunction)

注意:hashmap 是 HashMap 类的一个对象。

参数说明:

  • key - 键
  • remappingFunction - 重新映射函数,用于重新计算值

返回值

如果 key 对应的 value 不存在,则返回该 null,如果存在,则返回通过 remappingFunction 重新计算后的值。

二.源码

    default V computeIfPresent(K key,
            BiFunction<? super K, ? super V, ? extends V> remappingFunction) {
        Objects.requireNonNull(remappingFunction);
        V oldValue;
        if ((oldValue = get(key)) != null) {
            V newValue = remappingFunction.apply(key, oldValue);
            if (newValue != null) {
                put(key, newValue);
                return newValue;
            } else {
                remove(key);
                return null;
            }
        } else {
            return null;
        }
    }

三.实例

1.简单实例

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

        // 重新计算鞋加上10%的增值税后的价值
        int shoesPrice = prices.computeIfPresent("Shoes", (key, value) -> value + value * 10/100);
        System.out.println("Price of Shoes after VAT: " + shoesPrice);

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

执行以上程序输出结果为:

HashMap: {Pant=150, Bag=300, Shoes=200}
Price of Shoes after VAT: 220
Updated HashMap: {Pant=150, Bag=300, Shoes=220}}

2.开发实例

    /**
     * 将正在查看的未读消息MsgId缓存起来,防止ws重复发送已读消息
     */
    private static final Map<String, Set<String>> readMsgCache = new ConcurrentHashMap<>(2048);

    /**
     * 组装正在查看未读消息的MsgId缓存Key
     * @param appId
     * @param receive
     * @return
     */
    private static String getReadMsgCacheKey(String appId, Long receive) {
        return appId + "_" + receive;
    }

    /**
     * 将正在查看的消息缓存起来
     * @param appId 应用ID
     * @param receiverAccountId 接收人ID
     * @param msgIds 消息ID
     */
    public static void cacheReadMsg(String appId, Long receiverAccountId, List<String> msgIds) {
        readMsgCache.merge(getReadMsgCacheKey(appId, receiverAccountId), new HashSet<>(msgIds), (o, n) -> {
            o.addAll(n);
            return o;
        });
    }

    /**
     * 将缓存的未读消息移除
     * @param appId 应用ID
     * @param receiverAccountId 接收人ID
     * @param msgIds 消息ID
     */
    public static void removeCache(String appId, Long receiverAccountId, List<String> msgIds) {
        readMsgCache.computeIfPresent(getReadMsgCacheKey(appId, receiverAccountId), (k, v) -> {
            msgIds.forEach(v::remove);
            return v;
        });
    }

    /**
     * 获取正在查看未读消息的MsgId,防止ws重复发送未读消息
     * @param appId            应用ID
     * @param receiveAccountId 接收人ID
     * @return
     */
    public static Set<String> getReadMsgCache(String appId, Long receiveAccountId) {
        return readMsgCache.getOrDefault(getReadMsgCacheKey(appId, receiveAccountId), Collections.emptySet());
    }

标签:Map,return,HashMap,param,JDK8,key,appId,computeIfPresent
来源: https://blog.csdn.net/qq_42483764/article/details/121745255

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有