Java中HashMap遍历的两种方式

本文通过实例展示了HashMap在遍历时使用keySet与entrySet的不同效率,并提供了提高遍历效率的方法。
第一种:
  Map map =  HashMap();
  Iterator iter = map.entrySet().iterator();
   (iter.hasNext()) {
  Map.Entry entry = (Map.Entry) iter.next();
  Object key = entry.getKey();
  Object val = entry.getValue();
  }
  效率高,以后一定要使用此种方式!
第二种:
  Map map =  HashMap();
  Iterator iter = map.keySet().iterator();
   (iter.hasNext()) {
  Object key = iter.next();
  Object val = map.get(key);
  }
  效率低,以后尽量少使用!
 
       HashMap的遍历有两种常用的方法,那就是使用keyset及entryset来进行遍历,但两者的遍历速度是有差别的,下
面请看实例:
    HashMapTest {
     main(String[] args) ...{
  HashMap hashmap =  HashMap();
   ( i = 0; i < 1000; i ) ...{
  hashmap.put("" i, "thanks");
  }
   bs = Calendar.getInstance().getTimeInMillis();
  Iterator iterator = hashmap.keySet().iterator();
   (iterator.hasNext()) ...{
  System.out.print(hashmap.get(iterator.next()));
  }
  System.out.println();
  System.out.println(Calendar.getInstance().getTimeInMillis() - bs);
  listHashMap();
  }
     listHashMap() ...{
  java.util.HashMap hashmap =  java.util.HashMap();
   ( i = 0; i < 1000; i ) ...{
  hashmap.put("" i, "thanks");
  }
   bs = Calendar.getInstance().getTimeInMillis();
  java.util.Iterator it = hashmap.entrySet().iterator();
   (it.hasNext()) ...{
  java.util.Map.Entry entry = (java.util.Map.Entry) it.next();
    System.out.print(entry.getValue());
  }
  System.out.println();
  System.out.println(Calendar.getInstance().getTimeInMillis() - bs);
  }
  }
  对于keySet其实是遍历了2次,一次是转为iterator,一次就从hashmap中取出key所对于的value。而entryset只是
遍历了第一次,他把key和value都放到了entry中,所以就快了。


转载于:https://my.oschina.net/syso4yy/blog/389818

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值