深入理解Java 8 Map.computeIfAbsent方法

2024-02-29 20:36

本文主要是介绍深入理解Java 8 Map.computeIfAbsent方法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Java 8对Map接口进行了一系列的增强,引入了一些非常实用的默认方法。其中,computeIfAbsent方法是一个强大的工具,它可以帮助开发者优化代码,尤其是在处理映射时自动化键的存在性检查和值的懒初始化。这篇文章将带你深入理解computeIfAbsent方法,并通过一个简单的示例来展示它的用法和好处。

什么是 computeIfAbsent

computeIfAbsent 方法是Java 8中Map接口的一个默认方法。这个方法的作用是检查映射中是否已经有了指定的键,如果有,它就会返回键对应的值。如果没有,它会使用给定的函数来计算值,然后将键与计算出来的值关联在一起。

方法签名如下:

V computeIfAbsent(K key, Function<? super K, ? extends V> mappingFunction)
  • key 是你想要检查的键。
  • mappingFunction 是一个函数接口,用于在键不存在时计算值。

computeIfAbsent的优势

使用computeIfAbsent方法比传统方法有几个优势:

  • 减少代码冗余:它减少了检查键是否存在的冗余代码。
  • 原子操作:这个方法的执行是原子的,这对于并发编程来说是非常重要的。
  • 性能优化:它避免了不必要的对象创建,因为只有当键不存在时,才会计算值并创建新对象。
  • 代码简洁:它使代码更加简洁明了,更易于阅读和维护。

案例分析:跟踪博客作者的文章计数

让我们通过一个具体的例子来看看computeIfAbsent是如何工作的。假设我们正在编写一个博客平台,需要跟踪每个作者发布的文章数量。

在使用computeIfAbsent之前,我们可能会这样写代码:

Map<String, Integer> authorArticleCount = new HashMap<>();
String authorName = "John Doe";if (authorArticleCount.containsKey(authorName)) {int currentCount = authorArticleCount.get(authorName);authorArticleCount.put(authorName, currentCount + 1);
} else {authorArticleCount.put(authorName, 1);
}

使用computeIfAbsent方法,我们可以简化以上代码:

Map<String, Integer> authorArticleCount = new HashMap<>();
String authorName = "John Doe";// computeIfAbsent将自动处理新旧作者的计数
authorArticleCount.computeIfAbsent(authorName, k -> 0);
authorArticleCount.put(authorName, authorArticleCount.get(authorName) + 1);

在这个简化的版本中,computeIfAbsent方法自动检查authorName是否已经存在于映射中。如果不存在,它就会使用Lambda表达式k -> 0来计算默认值0,然后将这个值与authorName关联起来。如果authorName已经存在,它什么也不做。然后,无论键是否存在,我们都会增加其计数。

总结

computeIfAbsent方法是一个功能强大而且非常实用的工具,可以帮助我们编写更简洁、更高效的代码。它特别适用于需要对映射中的键进行存在性检查和值计算的场景。通过使用computeIfAbsent,我们可以减少模板代码,避免不必要的计算,并且使代码更加易于维护。

这篇关于深入理解Java 8 Map.computeIfAbsent方法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/759987

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

Java进阶13讲__第12讲_1/2

多线程、线程池 1.  线程概念 1.1  什么是线程 1.2  线程的好处 2.   创建线程的三种方式 注意事项 2.1  继承Thread类 2.1.1 认识  2.1.2  编码实现  package cn.hdc.oop10.Thread;import org.slf4j.Logger;import org.slf4j.LoggerFactory

认识、理解、分类——acm之搜索

普通搜索方法有两种:1、广度优先搜索;2、深度优先搜索; 更多搜索方法: 3、双向广度优先搜索; 4、启发式搜索(包括A*算法等); 搜索通常会用到的知识点:状态压缩(位压缩,利用hash思想压缩)。