java hashmap key类型

hashmap里面,对于key是int和string类型那个get的速度更快?希望懂的朋友,说下快的原因!首先,我个人的理解是,map是通过hashcode来查找的,即使... hashmap里面,对于key是int 和string类型 那个get的速度更快?
希望懂的朋友,说下快的原因!首先,我个人的理解是,map是通过hashcode来查找的,即使hashcode有冲突,不管key是Integer还是String,应该都不会影响速度吧?
展开
 我来答
yuboalt
推荐于2017-09-14 · TA获得超过578个赞
知道小有建树答主
回答量:509
采纳率:0%
帮助的人:204万
展开全部

JAVA中 如果用到Map集合 一般用的最多的就是HashMap.

Map集合在取值时用的key的类型必须和存放的时候用的key的类型一直.

比如,如果使用Integer类型的 1 作为key ,使用String 类型的 1 是取不到的.

所以一般建议在申明HashMap的时候就加入类型

HashMap<String,Object> map = new HashMap<String,Object>();

如果能确定Value的值,也可以申明清楚Value的值.

匿名用户
2012-06-14
展开全部
final Entry<K,V> removeEntryForKey(Object key) {
int hash = (key == null) ? 0 : hash(key.hashCode());
int i = indexFor(hash, table.length);
Entry<K,V> prev = table[i];
Entry<K,V> e = prev;

while (e != null) {
Entry<K,V> 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 是一样的
所以速度应该是一样的
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
匿名用户
2018-10-28
展开全部
key是Integer还是String在hashcode冲突时Integer更快,因为需要相等比较key.equals
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
s1m0n17
2012-06-14 · TA获得超过134个赞
知道答主
回答量:144
采纳率:0%
帮助的人:111万
展开全部
应该是一样快的
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
fylsh
2012-06-14 · TA获得超过950个赞
知道小有建树答主
回答量:1472
采纳率:0%
帮助的人:1033万
展开全部
都是一次查找成功情况下,int类型可能会快点
追问
能多说一点吗?
追答
Integer和String的hashcode产生真的是一样快吗?
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
收起 更多回答(3)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式