开发者

java中获取hashmap中的所有key方式

目录
  • 如何获取hashmap中的所有key
  • HashMap在获得Key的Hash值的时候用的是什么算法
    • JDK hashCode
  • 总结

    如何获取hashmap中的所有key

    在 Java 中,从 HashMap 中获取键的最简单方法是调用 HashMap 对象上的 keySet() 方法。

    它返回一个包含来自 HashMap 所有键的集合。

    如下代码所示:

    import java.util.HashMap;
    import java.util.Set;
    
    public class Test {
        /**
         * 使用递归反转字符串
         */
        pub编程客栈lic 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 (Strjavascripting key : keySet) {
                System.out.println(key);
            }
        }
    }
    

    java中获取hashmap中的所有key方式

    HashMap在获得Key的Hash值的时候用的是什么算法

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

    返回的结果是一个整数值。

    如果你查看 JDK 的源代码的话,在 HashMap 类中会有下面的这个方法。

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

    通过这个方法,我们可以看到返回的值是整数。

    java中获取hashmap中的所有key方式

    JDK hashCode

    如果我们继续跟踪代码,我们会看到在最最基础的 Object 对象中。

    有下面的代码:

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

    java中获取hashmap中的所有key方式

    是不是很奇怪,为什么这个类的名字为: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;
    					returphpn 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));
    				}
    			}
    		}
    android		return iden开发者_Python学习tityHashCode(anObject);
    	}

    java中获取hashmap中的所有key方式

    这个 hashCode 的方法被 IBM 提高了下,主要是看看输入的对象是不是 32 位的,如果是 32 位的,会用到 IBM 自己的方法。

    否则还是使用编程传统的 hashCode 方法。

    当然,对程序员来说,这部分的内容是透明的,程序员通常只需要知道 JDK 会在你对对象获得 hashCode 的时候返回一个整数值。

    在 HashMap 插入数据的时候需要计算 Hash 值,这个方法也会被用到。

    可以说这个方法是 JDK 的基础的基础了。

    总结

    以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。

    0

    上一篇:

    下一篇:

    精彩评论

    暂无评论...
    验证码 换一张
    取 消

    最新开发

    开发排行榜