java map的操作 与 遍历效率

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的遍历方法和以上的差不多
!

你可能感兴趣的:(java map的操作 与 遍历效率)