最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 正文

JAVA遍历Map所有元素

来源:动视网 责编:小OO 时间:2025-09-23 23:55:54
文档

JAVA遍历Map所有元素

JAVA遍历Map所有元素2010-03-0917:18//JDK1.5   Mapmap=newHashMap();     for(Objectobj:map.keySet()){         Objectkey=obj;         Objectvalue=map.get(obj);     }     //JDK1.4   Mapmap=  newHashMap()   ;     Iteratoriter=map.entrySet().iterator();     whil
推荐度:
导读JAVA遍历Map所有元素2010-03-0917:18//JDK1.5   Mapmap=newHashMap();     for(Objectobj:map.keySet()){         Objectkey=obj;         Objectvalue=map.get(obj);     }     //JDK1.4   Mapmap=  newHashMap()   ;     Iteratoriter=map.entrySet().iterator();     whil
JAVA遍历Map所有元素

2010-03-09 17:18

//JDK1.5   

Map map = new HashMap();     

for(Object obj : map.keySet()) {     

     Object key = obj;     

     Object value = map.get(obj);     

}   

  

//JDK1.4   

Map map =  new HashMap()    ;     

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

while(iter.hasNext()) {     

     Map.Entry entry = (Map.Entry)iter.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所有元素

JAVA遍历Map所有元素2010-03-0917:18//JDK1.5   Mapmap=newHashMap();     for(Objectobj:map.keySet()){         Objectkey=obj;         Objectvalue=map.get(obj);     }     //JDK1.4   Mapmap=  newHashMap()   ;     Iteratoriter=map.entrySet().iterator();     whil
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top