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

05容器篇(D2_集合 - D5_企业容器常用 API)

目录

一、computeIfAbsent()

二、removeIfAbsent()


一、computeIfAbsent()

编程中经常遇到这种数据结构,判断一个map中是否存在这个key,如果存在则处理value的数据,

如果不存在,则创建一个满足value要求的数据结构放到value中。

以前常用的方法如下:

编程中经常遇到这种数据结构,判断一个map中是否存在这个key,如果存在则处理value的数据,

如果不存在,则创建一个满足value要求的数据结构放到value中。

以前常用的方法如下:

public class TestComputeIfAbsent {
  static HashMap<String, Set<String>> hashMap = new HashMap<>();
  public static void main(String[] args) {
    Set<String> set = new HashSet<>();
    set.add("zhangSan");
    hashMap.put("china", set);
    // 判断map中是否存在,如果存在则添加元素到set中,如果不存在则新建set添加到hashMap中
    if(hashMap.containsKey("china")) {
      hashMap.get("china").add("liSi");
    } else {
      Set<String> setTmp = new HashSet<>();
      setTmp.add("liSi");
      hashMap.put("china", setTmp);
    }
    System.out.println(hashMap.toString());
  }
}

官方非常的贴心,为了满足广大用户的要求,加入了computeIfAbsent() 这个api,

使用后以上代码变成了下面的形式:

public class TestComputeIfAbsent {
  static HashMap<String, Set<String>> hashMap = new HashMap<>();
  public static void main(String[] args) {
    Set<String> set = new HashSet<>();
    set.add("zhangSan");
    hashMap.put("china", set);
    // after JDK1.8
    hashMap.computeIfAbsent("china", key -> getValues(key)).add("liSi");
    System.out.println(hashMap.toString());
  }
 
  public static HashSet getValues(String key) {
    return new HashSet();
  }
}

hashMap.computeIfAbsent("china", key -> getValues(key)).add("liSi");的意思表示key为“China”的建值对

是否存在,返回的是value的值。

如果存在则获取china的值,并操作值的set添加数据“lisi"。

如果不存在,则调用方法,新创建set结构,将"lisi"添加到set中,再存入到hashMap中。

二、removeIfAbsent()


http://www.kler.cn/a/471924.html

相关文章:

  • 【Rust自学】10.7. 生命周期 Pt.3:输入输出生命周期与3规则
  • java ShaUtils sha1如何生成签名?
  • uniapp下的手势事件
  • Vue 3 详解
  • 锂电池剩余寿命预测 | 基于BiLSTM-Attention的锂电池剩余寿命预测,附锂电池最新文章汇集
  • 2、zookeeper和kafka
  • List ---- 模拟实现LIST功能的发现
  • 23.行号没有了怎么办 滚动条没有了怎么办 C#例子
  • IP Anycast 与 CDN
  • c/c++ 里的进程间通信 , 管道 pipe 编程举例
  • 接口项目架构流程图-thinkphp6-rabbitmq
  • QT学习十九天 QT核心机制
  • WebRtc02: WebRtc架构、目录结构、运行机制
  • Lianwei 安全周报|2024.1.7
  • 【Java】JVM内存相关笔记
  • 代理IP授权机制:保障安全与效率的双重考量
  • matlab专栏-常见问题处理
  • 青少年编程与数学 02-006 前端开发框架VUE 12课题、表单绑定
  • C#高级:递归4-根据一颗树递归生成数据列表
  • 通过 ulimit 和 sysctl 调整Linux系统性能