溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

java中怎么獲取hashmap中所有的key

發(fā)布時(shí)間:2023-05-06 11:48:03 來源:億速云 閱讀:101 作者:iii 欄目:開發(fā)技術(shù)

這篇文章主要介紹了java中怎么獲取hashmap中所有的key的相關(guān)知識(shí),內(nèi)容詳細(xì)易懂,操作簡單快捷,具有一定借鑒價(jià)值,相信大家閱讀完這篇java中怎么獲取hashmap中所有的key文章都會(huì)有所收獲,下面我們一起來看看吧。

如何獲取hashmap中的所有key

在 Java 中,從 HashMap 中獲取鍵的最簡單方法是調(diào)用 HashMap 對象上的 keySet() 方法。

它返回一個(gè)包含來自 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);
        }
    }
}

java中怎么獲取hashmap中所有的key

HashMap在獲得Key的Hash值的時(shí)候用的是什么算法

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

返回的結(jié)果是一個(gè)整數(shù)值。

如果你查看 JDK 的源代碼的話,在 HashMap 類中會(huì)有下面的這個(gè)方法。

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

通過這個(gè)方法,我們可以看到返回的值是整數(shù)。

java中怎么獲取hashmap中所有的key

JDK hashCode

如果我們繼續(xù)跟蹤代碼,我們會(huì)看到在最最基礎(chǔ)的 Object 對象中。

有下面的代碼:

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

java中怎么獲取hashmap中所有的key

是不是很奇怪,為什么這個(gè)類的名字為: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);
	}

java中怎么獲取hashmap中所有的key

這個(gè) hashCode 的方法被 IBM 提高了下,主要是看看輸入的對象是不是 32 位的,如果是 32 位的,會(huì)用到 IBM 自己的方法。

否則還是使用傳統(tǒng)的 hashCode 方法。

當(dāng)然,對程序員來說,這部分的內(nèi)容是透明的,程序員通常只需要知道 JDK 會(huì)在你對對象獲得 hashCode 的時(shí)候返回一個(gè)整數(shù)值。

在 HashMap 插入數(shù)據(jù)的時(shí)候需要計(jì)算 Hash 值,這個(gè)方法也會(huì)被用到。

可以說這個(gè)方法是 JDK 的基礎(chǔ)的基礎(chǔ)了。

關(guān)于“java中怎么獲取hashmap中所有的key”這篇文章的內(nèi)容就介紹到這里,感謝各位的閱讀!相信大家對“java中怎么獲取hashmap中所有的key”知識(shí)都有一定的了解,大家如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI