posts - 110, comments - 101, trackbacks - 0, articles - 7
  BlogJava :: 首页 :: 新随笔 :: 联系 :: 聚合  :: 管理

java map的操作 与 遍历效率

Posted on 2011-05-12 21:13 云云 阅读(10251) 评论(3)  编辑  收藏
1.声明一个map: Map map = new HashMap(); 
2.向map中放值,注意:map是key-value的形式存放的.如:

map.put(”sa”,”dd”);

3.从map中取值:String str = map.get(”sa”).toString();结果是:str = ”dd”;

4.遍历一个map,从中取得key 和value

JDK1.
5

Map m 
= new HashMap(); 
for (Object o : map.keySet()) 
map.get(o); 
}


JDK1.
4

Map map 
= new HashMap() ; 

Iterator it 
= map.entrySet().iterator() ; 
while (it.hasNext()) 

Map.Entry entry 
= (Map.Entry) it.next() ; 
Object key 
= entry.getKey() ; 
Object value 
= entry.getValue() ; 
}

遍历效率对比:
第一种:

  Map map 
= new HashMap();

  Iterator iter 
= map.entrySet().iterator();

  
while (iter.hasNext()) {

  Map.Entry entry 
= (Map.Entry) iter.next(); Object key = entry.getKey();

  Object val 
= entry.getValue();

  }


  效率高,以后一定要使用此种方式
!

  第二种:

  Map map 
= new HashMap();

  Iterator iter 
= map.keySet().iterator();

  
while (iter.hasNext()) {

  Object key 
= iter.next();

  Object val 
= map.get(key);

  }


  效率低,以后尽量少使用
!

  HashMap的遍历有两种常用的方法,那就是使用keyset及entryset来进行遍历,但两者的遍历速度是有差别的,下面请看实例:

  
public class HashMapTest {

  
public static void main(String[] args) {

  HashMap hashmap 
= new HashMap();

  
for (int i = 0; i <1000; i ) {

  hashmap.put(
"" i, "thanks");

  }


  
long bs = Calendar.getInstance().getTimeInMillis();

  Iterator iterator 
= hashmap.keySet().iterator();

  
while (iterator.hasNext()) {

  System.out.print(hashmap.get(iterator.next()));

  }


  System.out.println();

  System.out.println(Calendar.getInstance().getTimeInMillis() 
- bs);

  listHashMap();

  }


  
public static void listHashMap() {

  java.util.HashMap hashmap 
= new java.util.HashMap();

  
for (int i = 0; i <1000; i ) {

  hashmap.put(
"" i, "thanks");

  }


  
long bs = Calendar.getInstance().getTimeInMillis();

  java.util.Iterator it 
= hashmap.entrySet().iterator();

  
while (it.hasNext()) {

  java.util.Map.Entry entry 
= (java.util.Map.Entry) it.next();

  
// entry.getKey() 返回与此项对应的键

  
// entry.getValue() 返回与此项对应的值

  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中,所以就快了。

  注:Hashtable的遍历方法和以上的差不多
!

评论

# ·1  回复  更多评论   

2015-09-09 15:55 by ·1
ABC的风格

# re: java map的操作 与 遍历效率  回复  更多评论   

2015-09-09 15:56 by ·11
213

# re: java map的操作 与 遍历效率  回复  更多评论   

2015-09-09 15:56 by ·11
@&#183;1

只有注册用户登录后才能发表评论。


网站导航: