您好,登錄后才能下訂單哦!
這篇文章主要介紹了java中怎么獲取hashmap中所有的key的相關知識,內容詳細易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇java中怎么獲取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); } } }
Java 在 HashMap Key 的 Hash 值的時候用的的是自己 Object 中的 hashCode() 算法。
返回的結果是一個整數值。
如果你查看 JDK 的源代碼的話,在 HashMap 類中會有下面的這個方法。
public final int hashCode() { return Objects.hashCode(key) ^ Objects.hashCode(value); }
通過這個方法,我們可以看到返回的值是整數。
如果我們繼續跟蹤代碼,我們會看到在最最基礎的 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中怎么獲取hashmap中所有的key”這篇文章的內容就介紹到這里,感謝各位的閱讀!相信大家對“java中怎么獲取hashmap中所有的key”知識都有一定的了解,大家如果還想學習更多知識,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。