hashMap一些不太常用但非常有用的方法及使用示例

HashMap 提供了多种方法来操作键值对,除了常用的 put()、get() 和 remove() 方法之外,还有一些不太常用但非常有用的方法。下面是几个不常用但很有用的 HashMap 方法及其使用示例:

  1. compute(K key, BiFunction<? super K, ? super V, ? extends V> remappingFunction)

此方法允许你基于现有值(如果存在)或计算新值,并将其放入映射中。

示例:

java 复制代码
import java.util.HashMap;
import java.util.function.BiFunction;

public class Main {
    public static void main(String[] args) {
        HashMap<String, Integer> map = new HashMap<>();
        map.put("apple", 1);
        
        // 如果有值,则增加1;如果没有,则设置为10
        BiFunction<String, Integer, Integer> function = (key, oldValue) -> oldValue == null ? 10 : oldValue + 1;
        map.compute("apple", function);
        System.out.println(map.get("apple")); // 输出: 2
        
        map.compute("banana", function);
        System.out.println(map.get("banana")); // 输出: 10
    }
}
  1. computeIfAbsent(K key, Function<? super K, ? extends V> mappingFunction)

当指定键没有对应值时,使用提供的映射函数计算其值并放入映射中。

示例:

java 复制代码
import java.util.HashMap;
import java.util.function.Function;

public class Main {
    public static void main(String[] args) {
        HashMap<String, Integer> map = new HashMap<>();
        
        Function<String, Integer> mappingFunction = key -> key.length();
        Integer value = map.computeIfAbsent("apple", mappingFunction);
        System.out.println(value); // 输出: 5
        
        // 已存在的键不会重新计算
        value = map.computeIfAbsent("apple", mappingFunction);
        System.out.println(value); // 输出: 5
    }
}
  1. computeIfPresent(K key, BiFunction<? super K, ? super V, ? extends V> remappingFunction)

只有在键对应的值非空时,才应用给定的重映射函数计算新值。

示例:

java 复制代码
import java.util.HashMap;
import java.util.function.BiFunction;

public class Main {
    public static void main(String[] args) {
        HashMap<String, Integer> map = new HashMap<>();
        map.put("apple", 1);
        
        BiFunction<String, Integer, Integer> remappingFunction = (key, oldValue) -> oldValue + 1;
        map.computeIfPresent("apple", remappingFunction);
        System.out.println(map.get("apple")); // 输出: 2
        
        // 对于不存在的键,不会执行任何操作
        map.computeIfPresent("banana", remappingFunction);
        System.out.println(map.containsKey("banana")); // 输出: false
    }
}
  1. merge(K key, V value, BiFunction<? super V, ? super V, ? extends V> remappingFunction)

如果指定的键尚未与某个值关联或关联的值为 null,则将该键与给定的值关联;否则,使用给定的重映射函数重新计算该键的新值。

示例:

java 复制代码
import java.util.HashMap;
import java.util.function.BiFunction;

public class Main {
    public static void main(String[] args) {
        HashMap<String, Integer> map = new HashMap<>();
        map.put("apple", 1);
        
        BiFunction<Integer, Integer, Integer> remappingFunction = Integer::sum;
        map.merge("apple", 2, remappingFunction);
        System.out.println(map.get("apple")); // 输出: 3
        
        map.merge("banana", 5, remappingFunction);
        System.out.println(map.get("banana")); // 输出: 5
    }
}
相关推荐
星火开发设计4 分钟前
类型别名 typedef:让复杂类型更简洁
开发语言·c++·学习·算法·函数·知识
qq_1777673716 分钟前
React Native鸿蒙跨平台数据使用监控应用技术,通过setInterval每5秒更新一次数据使用情况和套餐使用情况,模拟了真实应用中的数据监控场景
开发语言·前端·javascript·react native·react.js·ecmascript·harmonyos
达文汐17 分钟前
【困难】力扣算法题解析LeetCode332:重新安排行程
java·数据结构·经验分享·算法·leetcode·力扣
一匹电信狗17 分钟前
【LeetCode_21】合并两个有序链表
c语言·开发语言·数据结构·c++·算法·leetcode·stl
培风图南以星河揽胜18 分钟前
Java版LeetCode热题100之零钱兑换:动态规划经典问题深度解析
java·leetcode·动态规划
启山智软42 分钟前
【中大企业选择源码部署商城系统】
java·spring·商城开发
2401_8384725144 分钟前
C++中的访问者模式
开发语言·c++·算法
我真的是大笨蛋44 分钟前
深度解析InnoDB如何保障Buffer与磁盘数据一致性
java·数据库·sql·mysql·性能优化
csbysj20201 小时前
《Foundation 开关:深度解析其原理与应用》
开发语言
怪兽源码1 小时前
基于SpringBoot的选课调查系统
java·spring boot·后端·选课调查系统