当前位置: 首页 > news >正文

java map<String,List>判断是否有key,get(key.add(x),否则put(key,new list(){x})的新写法

在Java中,你可以通过几种方式实现这个逻辑。以下是几种常见的实现方法:

方法1:传统方式(使用 containsKey)

Map<String, List<String>> map = new HashMap<>(); public void addValue(String key, String value) { if (map.containsKey(key)) { map.get(key).add(value); } else { List<String> newList = new ArrayList<>(); newList.add(value); map.put(key, newList); } }

方法2:使用 getOrDefault(Java 8+)

Map<String, List<String>> map = new HashMap<>(); public void addValue(String key, String value) { List<String> list = map.getOrDefault(key, new ArrayList<>()); list.add(value); map.put(key, list); }

方法3:使用 computeIfAbsent(推荐,Java 8+)

Map<String, List<String>> map = new HashMap<>(); public void addValue(String key, String value) { map.computeIfAbsent(key, k -> new ArrayList<>()).add(value); }

方法4:使用 putIfAbsent

Map<String, List<String>> map = new HashMap<>(); public void addValue(String key, String value) { map.putIfAbsent(key, new ArrayList<>()); map.get(key).add(value); }

完整示例

import java.util.*; public class MapExample { public static void main(String[] args) { // 使用方法3:computeIfAbsent(最简洁) Map<String, List<String>> map = new HashMap<>(); addToMap(map, "fruit", "apple"); addToMap(map, "fruit", "banana"); addToMap(map, "vegetable", "carrot"); addToMap(map, "fruit", "orange"); System.out.println(map); // 输出: {vegetable=[carrot], fruit=[apple, banana, orange]} } // 使用 computeIfAbsent public static void addToMap(Map<String, List<String>> map, String key, String value) { map.computeIfAbsent(key, k -> new ArrayList<>()).add(value); } }

针对不同类型 List 的通用方法

如果你需要处理不同类型的数据,可以使用泛型:

public class MapUtils { // 通用方法 public static <K, V> void addToListInMap(Map<K, List<V>> map, K key, V value) { map.computeIfAbsent(key, k -> new ArrayList<>()).add(value); } // 使用示例 public static void main(String[] args) { Map<String, List<Integer>> intMap = new HashMap<>(); Map<String, List<Double>> doubleMap = new HashMap<>(); Map<String, List<Object>> objectMap = new HashMap<>(); addToListInMap(intMap, "scores", 100); addToListInMap(doubleMap, "prices", 19.99); addToListInMap(objectMap, "items", "item1"); } }

线程安全版本

如果需要在多线程环境中使用:

Map<String, List<String>> concurrentMap = new ConcurrentHashMap<>(); public void addValueSafely(String key, String value) { // 使用 ConcurrentHashMap 的 computeIfAbsent concurrentMap.computeIfAbsent(key, k -> Collections.synchronizedList(new ArrayList<>()) ).add(value); }

推荐

推荐使用方法3(computeIfAbsent),因为:

  1. 代码最简洁

  2. 避免多次访问Map

  3. 性能较好

  4. 是原子操作(在多线程环境下更安全)

如果你使用的是Java 8之前的版本,可以使用方法1,虽然代码稍长,但兼容性最好。

http://www.jsqmd.com/news/139541/

相关文章:

  • 计算机毕业设计springboot高考志愿推荐算法及其应用系统 SpringBoot框架下基于大数据的高考志愿智能匹配与可视化系统 面向新高考改革的Java志愿推荐引擎与线上辅助填报平台
  • 口碑与实力兼具:丁基胶带供应商的优质选择
  • HTTP中的四次挥手
  • 微信小程序uniapp-vue祛痘美容减肥个人健康交流打卡
  • 禅道的操作与抓包
  • 2025最新!9款AI论文软件测评:研究生写论文痛点全解析
  • 基于Python+Django岛滨海学院增值性评价课程考核系统(源码+讲解视频+LW)
  • 高性价比丁基胶带工厂及选购指南
  • springboot大学城水电管理系统(11585)
  • ToDesk 2026 重磅更新:支持8k画质!专业玩家和设计师坐不住了
  • 0基础保姆级教程:8大智能体设计模式,看完就能动手做AI助手
  • 布局对话框
  • HTTP安全攻防:常见漏洞原理与防护措施(附练习题)
  • TCP\IP和https流程
  • 基于Comsol的高坝应力渗流耦合三维分析探索
  • HTTP核心头字段记忆口诀
  • zszsbd
  • 实用指南:天机学堂day09学习
  • hot100 142.环形链表Ⅱ
  • 2025.12.25作业
  • 探寻电池精品定制之路,聚电新能源引领行业新高度
  • 0x3f第13天复习 (12:40-17:45)
  • VMware Workstation 挂载共享文件夹
  • 人工智能通识作业
  • 2025论文神器终极榜单:7款工具带真实参考文献,查重低原创高!
  • 【毕业设计】基于springboot的学院失物招领平台的设计与实现(源码+文档+远程调试,全bao定制等)
  • 汉诺塔递归函数,农夫抓牛问题,数字金字塔最大路径和问题
  • 深入浅出理解Spring Boot中的依赖注入
  • 人工智能作业--光的折射
  • 口碑佳且可个性化定制的丁基胶带供应商推荐