这篇文章主要介绍了java中怎么获取hashmap中所有的key的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇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 的基础的基础了。