java中獲取hashmap中的所有key方式
如何獲取hashmap中的所有key
在 Java 中,從 HashMap 中獲取鍵的最簡(jiǎn)單方法是調(diào)用 HashMap 對(duì)象上的 keySet() 方法。
它返回一個(gè)包含來(lái)自 HashMap 所有鍵的集合。
如下代碼所示:
import java.util.HashMap; import java.util.Set; public class Test { /** * 使用遞歸反轉(zhuǎn)字符串 */ public static void main(String[] args) { //先創(chuàng)建一個(gè)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值的時(shí)候用的是什么算法
Java 在 HashMap Key 的 Hash 值的時(shí)候用的的是自己 Object 中的 hashCode() 算法。
返回的結(jié)果是一個(gè)整數(shù)值。
如果你查看 JDK 的源代碼的話(huà),在 HashMap 類(lèi)中會(huì)有下面的這個(gè)方法。
public final int hashCode() { return Objects.hashCode(key) ^ Objects.hashCode(value); }
通過(guò)這個(gè)方法,我們可以看到返回的值是整數(shù)。
JDK hashCode
如果我們繼續(xù)跟蹤代碼,我們會(huì)看到在最最基礎(chǔ)的 Object 對(duì)象中。
有下面的代碼:
public int hashCode() { return J9VMInternals.fastIdentityHashCode(this); }
是不是很奇怪,為什么這個(gè)類(lèi)的名字為:J9VMInternals
這是因?yàn)槲覀兊臋C(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); }
這個(gè) hashCode 的方法被 IBM 提高了下,主要是看看輸入的對(duì)象是不是 32 位的,如果是 32 位的,會(huì)用到 IBM 自己的方法。
否則還是使用傳統(tǒng)的 hashCode 方法。
當(dāng)然,對(duì)程序員來(lái)說(shuō),這部分的內(nèi)容是透明的,程序員通常只需要知道 JDK 會(huì)在你對(duì)對(duì)象獲得 hashCode 的時(shí)候返回一個(gè)整數(shù)值。
在 HashMap 插入數(shù)據(jù)的時(shí)候需要計(jì)算 Hash 值,這個(gè)方法也會(huì)被用到。
可以說(shuō)這個(gè)方法是 JDK 的基礎(chǔ)的基礎(chǔ)了。
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
SpringBoot2 實(shí)現(xiàn)JPA分頁(yè)和排序分頁(yè)的案例
這篇文章主要介紹了SpringBoot2 實(shí)現(xiàn)JPA分頁(yè)和排序分頁(yè)的案例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-01-01Java中過(guò)濾器、監(jiān)聽(tīng)器和攔截器的區(qū)別詳解
這篇文章主要介紹了Java中過(guò)濾器、監(jiān)聽(tīng)器和攔截器的區(qū)別詳解,有些朋友可能不了解過(guò)濾器、監(jiān)聽(tīng)器和攔截器的區(qū)別,本文就來(lái)詳細(xì)講一下,相信看完你會(huì)有所收獲,需要的朋友可以參考下2024-01-01Redis6搭建集群并在SpringBoot中使用RedisTemplate的實(shí)現(xiàn)
本文主要介紹了Redis6搭建集群并在SpringBoot中使用RedisTemplate,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-04-04SpringBoot基于HttpMessageConverter實(shí)現(xiàn)全局日期格式化
這篇文章主要介紹了SpringBoot基于HttpMessageConverter實(shí)現(xiàn)全局日期格式化,使用Jackson消息轉(zhuǎn)換器,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2018-12-12springboot整合vue實(shí)現(xiàn)上傳下載文件
這篇文章主要為大家詳細(xì)介紹了springboot整合vue實(shí)現(xiàn)上傳下載文件,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-11-11