java HashMap与Hashtable 的遍历

    概述:

    java中 HashMap 与Hashtable的遍历方式相同,有三种方式,分别是通过entry,key,value来进行遍历,下面以HashMap为例进行学习:

一、entrySet遍历

    写法一:

Iterator<Entry<String, String>> iter = map.entrySet().iterator();

Entry<String, String> entry;

while (iter.hasNext()) {

    entry = iter.next();

    key = entry.getKey();

    value = entry.getValue();

}
     写法二:

for (Entry<String, String> entry: map.entrySet()) {

    key = entry.getKey();

    value = entry.getValue();

}

hashMap的entrySet方法:返回此映射所包含的映射关系的 collection 视图。

Map.entry :是map接口的一个内部接口,他的作用就是包装一个map的节点,这个节封装了key,value,以及别的值(比如hashmap中的哈希码和next指针)

二、keySet遍历

    写法一:

Iterator<Object> iter = map.keySet().iterator();

while (iter.hasNext()) {

Object   key = iter.next();

Object   value = map.get(key);

}

     写法二:

for (Object k : map.keySet()) {
//Object key = k;
Object  value = map.get(k);

}

hashMap的keySet方法:返回此映射中所包含的键的 set 视图。

三、values遍历

    写法一:

Iterator<Object> iter = map.values().iterator();

while (iter.hasNext()) {

Object  value = iter.next();

}

    写法二:

for (Object value : map.values()) {

}

hashMap的values方法:返回此映射所包含的值的 collection 视图。

四、遍历方式的选择

    1、同时遍历key和value时,keySet与entrySet方法的性能差异取决于key的具体情况,如复杂度(复杂对象)、离散度、冲突率等。换言之,取决于HashMap查找value的开销。entrySet一次性取出所有key和value的操作是有性能开销的,当这个损失小于HashMap查找value的开销时,entrySet的性能优势就会体现出来。总体来说还是推荐使用entrySet。因为当key很简单时,其性能或许会略低于keySet,但却是可控的;而随着key的复杂化,entrySet的优势将会明显体现出来。

    2、只遍历key时,keySet方法更为合适,因为entrySet将无用的value也给取出来了,浪费了性能和空间。在上述测试结果中,keySet比entrySet方法耗时少23%。

    3、只遍历value时,使用vlaues方法是最佳选择,entrySet会略好于keySet方法。

    4、在不同的遍历写法中,推荐使用写法二的方式,其效率略高一些。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值