java hashmap key类型
答案:4 悬赏:0 手机版
解决时间 2021-04-02 17:50
- 提问者网友:暮烟疏雨之际
- 2021-04-02 00:01
java hashmap key类型
最佳答案
- 五星知识达人网友:拾荒鲤
- 2021-04-02 00:36
JAVA中 如果用到Map集合 一般用的最多的就是HashMap.
Map集合在取值时用的key的类型必须和存放的时候用的key的类型一直.
比如,如果使用Integer类型的 1 作为key ,使用String 类型的 1 是取不到的.
所以一般建议在申明HashMap的时候就加入类型
HashMap map = new HashMap();如果能确定Value的值,也可以申明清楚Value的值.
Map集合在取值时用的key的类型必须和存放的时候用的key的类型一直.
比如,如果使用Integer类型的 1 作为key ,使用String 类型的 1 是取不到的.
所以一般建议在申明HashMap的时候就加入类型
HashMap
全部回答
- 1楼网友:一叶十三刺
- 2021-04-02 01:45
应该是一样快的
- 2楼网友:轻雾山林
- 2021-04-02 01:39
final Entry removeEntryForKey(Object key) {
int hash = (key == null) ? 0 : hash(key.hashCode());
int i = indexFor(hash, table.length);
Entry prev = table[i];
Entry e = prev;
while (e != null) {
Entry next = e.next;
Object k;
if (e.hash == hash &&
((k = e.key) == key || (key != null && key.equals(k)))) {
modCount++;
size--;
if (prev == e)
table[i] = next;
else
prev.next = next;
e.recordRemoval(this);
return e;
}
prev = e;
e = next;
}
return e;
}
HashMap移除对象的一个函数
可以看出是通过Key的hash值寻找 Integer 和String 应该查不多
hashCode()方法继承自Object 谁对象生成的一个固定整型值 Integer 和String 是一样的
所以速度应该是一样的
int hash = (key == null) ? 0 : hash(key.hashCode());
int i = indexFor(hash, table.length);
Entry
Entry
while (e != null) {
Entry
Object k;
if (e.hash == hash &&
((k = e.key) == key || (key != null && key.equals(k)))) {
modCount++;
size--;
if (prev == e)
table[i] = next;
else
prev.next = next;
e.recordRemoval(this);
return e;
}
prev = e;
e = next;
}
return e;
}
HashMap移除对象的一个函数
可以看出是通过Key的hash值寻找 Integer 和String 应该查不多
hashCode()方法继承自Object 谁对象生成的一个固定整型值 Integer 和String 是一样的
所以速度应该是一样的
- 3楼网友:举杯邀酒敬孤独
- 2021-04-02 00:42
都是一次查找成功情况下,int类型可能会快点追问能多说一点吗?追答Integer和String的hashcode产生真的是一样快吗?
我要举报
如以上问答信息为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
大家都在看
推荐资讯