`
john201314
  • 浏览: 8107 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类

HashMap 取值应注意key的类型

    博客分类:
  • java
阅读更多
 Map<Long,String> hashMap = new HashMap<Long,String>();
        hashMap.put(new Long(1), "A");
        System.out.println(hashMap.get(new Integer(1)));

发现取的值为null.

这是因为取值的时候没有与key的类型匹配。

这是取值的逻辑代码
   final Entry<K,V> getEntry(Object key) {
        int hash = (key == null) ? 0 : hash(key);
        for (Entry<K,V> e = table[indexFor(hash, table.length)];
             e != null;
             e = e.next) {
            Object k;
            if (e.hash == hash &&
                ((k = e.key) == key || (key != null && key.equals(k))))
                return e;
        }
        return null;
    }


但是Integer的equals方法
  public boolean equals(Object obj) {
        if (obj instanceof Integer) {
            return value == ((Integer)obj).intValue();
        }
        return false;
    }


Long的equals方法
  public boolean equals(Object obj) {
        if (obj instanceof Long) {
            return value == ((Long)obj).longValue();
        }
        return false;
    }


即使值相等,但因为类型不匹配,并且HashMap接受的参数类型是Object,它这样设计的用途是为了所有的类型都通用。但是HashMap本身就没声明说,一定要类型对才能取值。
哈哈以后要注意了。
0
0
分享到:
评论

相关推荐

    HashMap通过VALUE反向求KEY的方法

    HashMap中的值是成对地放置的,即VALUE-KEY.因此我们一般在MAP中取出数据时得根据KEY来取出VALUE.但若我们想出VALUE值,但却不知对应地KEY,这时我们就得先遍历VALUE值,找出对应地KEY值,再根据KEY值取出VALUE值

    简单的key value hashmap

    简单的hashmap key、value方便以后直接用。

    flex HashMap

    flex 封装的一个HashMap。使用挺方便的。(免积分下载)

    HashMap&ConcurrentHashMap.key

    HashMap& ConcurrentHashMap 深度解析

    HashMap根据value获取key值

    Map集合的特性:一个key值对应一个value值,key值保持着唯一性,而插入的键值对相同key值会发生覆盖原key值对应的value值。 Map集合中一个key对应一个value,但是一个相同的value值可以对应多个key值 下面我们来根据...

    HashMap原理.docx

    HashMap是一个散列桶(数组和链表),它存储的内容是键值对(key-value)映射HashMap采用了数组和链表的数据结构,能在查询和修改方便继承了数组的线性查找和链表的寻址修改HashMap是非synchronized,所以HashMap很快...

    hashmap 实例

    hashmap实例 hashmap实例hashmap实例hashmap实例

    HashMap介绍和使用

    HashMap介绍和使用

    hashmap面试题_hashmap_

    hashmap相关的面试题

    java程序员面试题

    HashMap是Hashtable的轻量级实现(非线程安全的实现),他们都完成了Map接口,主要区别在于HashMap允许空(null)键值(key),由于非线程安全,效率上可能高于Hashtable。 HashMap允许将null作为一个entry的key或者...

    HashMap部分源码分析

    HashMap数据结构,HashMap的构造方法,HashMap的put,HashMap的get

    java HashMap原理分析

    详细分析HashMap的存储原理,key值的hash地址以及扩容

    HASHMAP排序功能描述

    HASHMAP排序,对一个无序以KEY为数字的MAP进行排序,比较简单操作

    HashMap存放.doc

    HashMap存放.doc

    java HashMap通过value反查key的代码示例

    本文讲解了java HashMap通过value反查key的方法,直接提供代码供大家参考使用

    Hashmap详解

    Hashmap详解

    HashMap面试总结.docx

    HashMap是一个存储key-value的键值对集合,每一个元素都是一个Entry,这些键值对分散在数组当中。 你为什么要用HashMap? 1.解决问题需要的数据结构是一种键值对的数据结构 2.HashMap是线程不安全的,其速度比较快 3....

    HashMap排序

    hashMap排序,hashmap使用还是比较频繁。这时自己写的一个实现hashmap排序的例子

    Javascript实现和操作HashMap

    Javascript实现和操作HashMap,压缩包里面有hashmap定义和操作的例子

    hashmap实现原理

    hashmap的底层及源码解析,很适合大家的学习,不要积分。

Global site tag (gtag.js) - Google Analytics