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本身就没声明说,一定要类型对才能取值。
哈哈以后要注意了。
分享到:
相关推荐
HashMap中的值是成对地放置的,即VALUE-KEY.因此我们一般在MAP中取出数据时得根据KEY来取出VALUE.但若我们想出VALUE值,但却不知对应地KEY,这时我们就得先遍历VALUE值,找出对应地KEY值,再根据KEY值取出VALUE值
简单的hashmap key、value方便以后直接用。
flex 封装的一个HashMap。使用挺方便的。(免积分下载)
HashMap& ConcurrentHashMap 深度解析
Map集合的特性:一个key值对应一个value值,key值保持着唯一性,而插入的键值对相同key值会发生覆盖原key值对应的value值。 Map集合中一个key对应一个value,但是一个相同的value值可以对应多个key值 下面我们来根据...
HashMap是一个散列桶(数组和链表),它存储的内容是键值对(key-value)映射HashMap采用了数组和链表的数据结构,能在查询和修改方便继承了数组的线性查找和链表的寻址修改HashMap是非synchronized,所以HashMap很快...
hashmap实例 hashmap实例hashmap实例hashmap实例
HashMap介绍和使用
hashmap相关的面试题
HashMap是Hashtable的轻量级实现(非线程安全的实现),他们都完成了Map接口,主要区别在于HashMap允许空(null)键值(key),由于非线程安全,效率上可能高于Hashtable。 HashMap允许将null作为一个entry的key或者...
HashMap数据结构,HashMap的构造方法,HashMap的put,HashMap的get
详细分析HashMap的存储原理,key值的hash地址以及扩容
HASHMAP排序,对一个无序以KEY为数字的MAP进行排序,比较简单操作
HashMap存放.doc
本文讲解了java HashMap通过value反查key的方法,直接提供代码供大家参考使用
Hashmap详解
HashMap是一个存储key-value的键值对集合,每一个元素都是一个Entry,这些键值对分散在数组当中。 你为什么要用HashMap? 1.解决问题需要的数据结构是一种键值对的数据结构 2.HashMap是线程不安全的,其速度比较快 3....
hashMap排序,hashmap使用还是比较频繁。这时自己写的一个实现hashmap排序的例子
Javascript实现和操作HashMap,压缩包里面有hashmap定义和操作的例子
hashmap的底层及源码解析,很适合大家的学习,不要积分。