java中獲取hashmap中的所有key方式
如何獲取hashmap中的所有key
在 Java 中,從 HashMap 中獲取鍵的最簡單方法是調(diào)用 HashMap 對象上的 keySet() 方法。
它返回一個包含來自 HashMap 所有鍵的集合。
如下代碼所示:
import java.util.HashMap;
import java.util.Set;
public class Test {
/**
* 使用遞歸反轉(zhuǎn)字符串
*/
public static void main(String[] args) {
//先創(chuàng)建一個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() 算法。
返回的結(jié)果是一個整數(shù)值。
如果你查看 JDK 的源代碼的話,在 HashMap 類中會有下面的這個方法。
public final int hashCode() {
return Objects.hashCode(key) ^ Objects.hashCode(value);
}通過這個方法,我們可以看到返回的值是整數(shù)。

JDK hashCode
如果我們繼續(xù)跟蹤代碼,我們會看到在最最基礎(chǔ)的 Object 對象中。
有下面的代碼:
public int hashCode() {
return J9VMInternals.fastIdentityHashCode(this);
}
是不是很奇怪,為什么這個類的名字為:J9VMInternals
這是因為我們的機(jī)器裝的是 IBM 的 OpenJ9 虛擬機(jī)的版本。
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 自己的方法。
否則還是使用傳統(tǒng)的 hashCode 方法。
當(dāng)然,對程序員來說,這部分的內(nèi)容是透明的,程序員通常只需要知道 JDK 會在你對對象獲得 hashCode 的時候返回一個整數(shù)值。
在 HashMap 插入數(shù)據(jù)的時候需要計算 Hash 值,這個方法也會被用到。
可以說這個方法是 JDK 的基礎(chǔ)的基礎(chǔ)了。
總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
Java中的interrupted()和isInterrupted()
這篇文章主要介紹了Java中的interrupted()和isInterrupted()摸下面文章圍繞interrupted()和isInterrupted()的相關(guān)資料展開詳細(xì)內(nèi)容,需要的小伙伴樂意參考下面下面文章具體價紹,希望對大家有所幫助2021-11-11
SpringMVC實現(xiàn)全局異常處理器的經(jīng)典案例
文章介紹了如何使用@ControllerAdvice和相關(guān)注解實現(xiàn)SpringMVC的全局異常處理,通過統(tǒng)一的異常處理類和自定義業(yè)務(wù)異常類,可以將所有控制器的異常集中處理,并以JSON格式返回給前端,感興趣的朋友一起看看吧2025-03-03
Java輸入流Scanner/BufferedReader使用方法示例
這篇文章主要介紹了Java輸入流Scanner/BufferedReader使用方法,大家看示例吧2013-11-11
JavaWeb項目實現(xiàn)文件上傳動態(tài)顯示進(jìn)度實例
本篇文章主要介紹了JavaWeb項目實現(xiàn)文件上傳動態(tài)顯示進(jìn)度實例,具有一定的參考價值,有興趣的可以了解一下。2017-04-04
Java線程池ForkJoinPool(工作竊取算法)的使用
Fork就是把一個大任務(wù)切分為若干個子任務(wù)并行地執(zhí)行,Join就是合并這些子任務(wù)的執(zhí)行結(jié)果,最后得到這個大任務(wù)的結(jié)果。Fork/Join?框架使用的是工作竊取算法。本文主要介紹了ForkJoinPool的使用,需要的可以參考一下2022-11-11

