java map判断是否有key,get(key)+x,否则put(key,x)的新写法

在Java中,可以使用以下几种方式判断Map中是否有key,并进行相应操作:

1. 使用 containsKey()方法(最直观)

复制代码
Map<String, Integer> map = new HashMap<>();

// 方法1:先判断是否存在
if (map.containsKey(key)) {
    map.put(key, map.get(key) + x);
} else {
    map.put(key, x);
}

2. 使用 get()方法判断null(推荐)

复制代码
Map<String, Integer> map = new HashMap<>();

// 方法2:通过get()返回值判断
Integer value = map.get(key);
if (value != null) {
    map.put(key, value + x);
} else {
    map.put(key, x);
}

3. 使用 merge()方法(Java 8+ 最简洁)

复制代码
Map<String, Integer> map = new HashMap<>();

// 方法3:使用merge方法(推荐)
map.merge(key, x, (oldValue, newValue) -> oldValue + newValue);
// 或者使用Integer::sum
map.merge(key, x, Integer::sum);

4. 使用 getOrDefault()方法(Java 8+)

复制代码
Map<String, Integer> map = new HashMap<>();

// 方法4:getOrDefault获取当前值
int currentValue = map.getOrDefault(key, 0);
map.put(key, currentValue + x);

5. 使用 compute()方法(Java 8+)

复制代码
Map<String, Integer> map = new HashMap<>();

// 方法5:使用compute方法
map.compute(key, (k, v) -> v == null ? x : v + x);

性能对比和推荐

方法 优点 缺点
containsKey() 直观易懂,兼容性好 需要两次查找(containsKey + get)
get()判断null 一次查找,性能较好 需要处理null值
merge() 代码简洁,线程安全(在ConcurrentHashMap中) Java 8+ 才支持
getOrDefault() 代码简洁 需要额外变量
compute() 功能强大 代码可读性稍差

推荐: ​ 如果使用Java 8+,优先使用merge()方法,因为它最简洁且性能好。如果使用更早版本,推荐使用get()判断null的方式。

相关推荐
与遨游于天地9 分钟前
NIO的三个组件解决三个问题
java·后端·nio
czlczl2002092535 分钟前
Guava Cache 原理与实战
java·后端·spring
徐先生 @_@|||36 分钟前
Palantir Foundry 五层架构模型详解
开发语言·python·深度学习·算法·机器学习·架构
yangminlei37 分钟前
Spring 事务探秘:核心机制与应用场景解析
java·spring boot
tang777891 小时前
爬虫如何绕过绕过“5秒盾”Cloudflare:从浏览器指纹模拟到Rust求解之不完全指南
开发语言·爬虫·rust·cloudflare
Yuer20251 小时前
什么是 Rust 语境下的“量化算子”——一个工程对象的最小定义
开发语言·后端·rust·edca os·可控ai
hqwest1 小时前
码上通QT实战26--系统设置01-系统设置布局
开发语言·qt·qss·qt基础控件·qt布局控件·qt表格控件
薛定谔的猫19822 小时前
llama-index Embedding 落地到 RAG 系统
开发语言·人工智能·python·llama-index
记得开心一点嘛2 小时前
Redis封装类
java·redis
lkbhua莱克瓦242 小时前
进阶-存储过程3-存储函数
java·数据库·sql·mysql·数据库优化·视图