java中获取hashmap中的所有key方式

 更新时间:2023年03月22日 14:28:54   作者:不二901  
这篇文章主要介绍了java中获取hashmap中的所有key方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

如何获取hashmap中的所有key

在 Java 中,从 HashMap 中获取键的最简单方法是调用 HashMap 对象上的 keySet() 方法。

它返回一个包含来自 HashMap 所有键的集合。

如下代码所示:

import java.util.HashMap;
import java.util.Set;

public class Test {
    /**
     * 使用递归反转字符串
     */
    public static void main(String[] args) {

        //先创建一个hashmap
        HashMap<String, Integer> map = new HashMap<>();
        map.put("张三", 65);
        map.put("李四", 84);
        map.put("王五", 75);
        map.put("王二麻子", 85);
        //获取所有的可以值
        Set<String> keySet = map.keySet();
        //遍历
        for (String key : keySet) {
            System.out.println(key);
        }
    }
}

HashMap在获得Key的Hash值的时候用的是什么算法

Java 在 HashMap Key 的 Hash 值的时候用的的是自己 Object 中的 hashCode() 算法。

返回的结果是一个整数值。

如果你查看 JDK 的源代码的话,在 HashMap 类中会有下面的这个方法。

        public final int hashCode() {
            return Objects.hashCode(key) ^ Objects.hashCode(value);
        }

通过这个方法,我们可以看到返回的值是整数。

JDK hashCode

如果我们继续跟踪代码,我们会看到在最最基础的 Object 对象中。

有下面的代码:

public int hashCode() {
	return J9VMInternals.fastIdentityHashCode(this);
}

是不是很奇怪,为什么这个类的名字为:J9VMInternals

这是因为我们的机器装的是 IBM 的 OpenJ9 虚拟机的版本。

IBM 在这里定义了自己的获得 hashCode 的方法。

	static int fastIdentityHashCode(Object anObject) {
		com.ibm.jit.JITHelpers h = jitHelpers;
		if (null == h) {
			return identityHashCode(anObject); /* use early returns to make the JIT code faster */
		}
		if (h.is32Bit()) {
			int ptr = h.getIntFromObject(anObject, 0L);
			if ((ptr & com.ibm.oti.vm.VM.OBJECT_HEADER_HAS_BEEN_MOVED_IN_CLASS) != 0) {
				if (!h.isArray(anObject)) {
					int j9class = ptr & com.ibm.oti.vm.VM.J9_JAVA_CLASS_MASK;
					return h.getIntFromObject(anObject, h.getBackfillOffsetFromJ9Class32(j9class));
				}
			}
		} else {
			long ptr = (com.ibm.oti.vm.VM.FJ9OBJECT_SIZE == 4) ? Integer.toUnsignedLong(h.getIntFromObject(anObject, 0L)) : h.getLongFromObject(anObject, 0L);
			if ((ptr & com.ibm.oti.vm.VM.OBJECT_HEADER_HAS_BEEN_MOVED_IN_CLASS) != 0) {
				if (!h.isArray(anObject)) {
					long j9class = ptr & com.ibm.oti.vm.VM.J9_JAVA_CLASS_MASK;
					return h.getIntFromObject(anObject, h.getBackfillOffsetFromJ9Class64(j9class));
				}
			}
		}
		return identityHashCode(anObject);
	}

这个 hashCode 的方法被 IBM 提高了下,主要是看看输入的对象是不是 32 位的,如果是 32 位的,会用到 IBM 自己的方法。

否则还是使用传统的 hashCode 方法。

当然,对程序员来说,这部分的内容是透明的,程序员通常只需要知道 JDK 会在你对对象获得 hashCode 的时候返回一个整数值。

在 HashMap 插入数据的时候需要计算 Hash 值,这个方法也会被用到。

可以说这个方法是 JDK 的基础的基础了。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • 一篇文章带你入门java泛型

    一篇文章带你入门java泛型

    这篇文章主要介绍了java泛型基础知识及通用方法,从以下几个方面介绍一下java的泛型: 基础, 泛型关键字, 泛型方法, 泛型类和接口,感兴趣的可以了解一下
    2021-08-08
  • Java中的interrupted()和isInterrupted()

    Java中的interrupted()和isInterrupted()

    这篇文章主要介绍了Java中的interrupted()和isInterrupted()摸下面文章围绕interrupted()和isInterrupted()的相关资料展开详细内容,需要的小伙伴乐意参考下面下面文章具体价绍,希望对大家有所帮助
    2021-11-11
  • SpringMVC实现全局异常处理器的经典案例

    SpringMVC实现全局异常处理器的经典案例

    文章介绍了如何使用@ControllerAdvice和相关注解实现SpringMVC的全局异常处理,通过统一的异常处理类和自定义业务异常类,可以将所有控制器的异常集中处理,并以JSON格式返回给前端,感兴趣的朋友一起看看吧
    2025-03-03
  • spring boot整合Cucumber(BDD)的方法

    spring boot整合Cucumber(BDD)的方法

    本篇文章主要介绍了spring boot整合Cucumber(BDD)的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-04-04
  • SpringBoot HTTP 400排查方式

    SpringBoot HTTP 400排查方式

    这篇文章主要介绍了SpringBoot HTTP 400排查方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-08-08
  • javaweb中ajax请求后台servlet(实例)

    javaweb中ajax请求后台servlet(实例)

    下面小编就为大家带来一篇javaweb中ajax请求后台servlet(实例)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-06-06
  • Java输入流Scanner/BufferedReader使用方法示例

    Java输入流Scanner/BufferedReader使用方法示例

    这篇文章主要介绍了Java输入流Scanner/BufferedReader使用方法,大家看示例吧
    2013-11-11
  • JavaWeb项目实现文件上传动态显示进度实例

    JavaWeb项目实现文件上传动态显示进度实例

    本篇文章主要介绍了JavaWeb项目实现文件上传动态显示进度实例,具有一定的参考价值,有兴趣的可以了解一下。
    2017-04-04
  • 23种设计模式(21)java享元模式

    23种设计模式(21)java享元模式

    这篇文章主要为大家详细介绍了23种设计模式之java享元模式,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-01-01
  • Java线程池ForkJoinPool(工作窃取算法)的使用

    Java线程池ForkJoinPool(工作窃取算法)的使用

    Fork就是把一个大任务切分为若干个子任务并行地执行,Join就是合并这些子任务的执行结果,最后得到这个大任务的结果。Fork/Join 框架使用的是工作窃取算法。本文主要介绍了ForkJoinPool的使用,需要的可以参考一下
    2022-11-11

最新评论