java

关注公众号 jb51net

关闭
首页 > 软件编程 > java > Java遍历Map

Java遍历Map的5种方式实例

作者:花果水莲

Map作为Java中的一种集合,以键值对的形式存放一批数据,经常会被我们应用在项目中,下面这篇文章主要给大家介绍了关于Java遍历Map的5种方式,需要的朋友可以参考下

一、遍历Map的五种方式

java中遍历map一般有五种方法,从最早的Iterator,到java5支持的foreach,再到java8的Lambda表达式。

二、准备条件

初始化一个map

Map<Integer,Integer> map= new HashMap<>();
for(int i=0;i<10000;i++){
    map.put(i,i+1);
}

三、keySet和values方式遍历

如果只是需要获取map的key或者value,用map的keySet或values方法无疑时最方便的

//keySet获取key
@Test
public  void testKeySet(){
    for (Integer key: map.keySet()){
        System.out.println(key);
    }
}
 
//values获取value
@Test
public  void testValues(){
   for (Integer value: map.values()){
       System.out.println(value);
   }
}

四、keySet和get(key)方式遍历map

如果需要同时获取key和value,可以先获取key,然后再通过map的get(key)获取value,需要说明的是,该方法不是最优解,一般不推荐使用。

//keySet get(key)获取key 和value
    @Test
    public void testKeySetAndGetKey(){
        for(Integer key: map.keySet()){
            System.out.println(key+":"+map.get(key));
        }
    }

五、entrySet方式遍历map

通过对map entrySet的遍历,也可以同时拿到key和value,一般情况下,性能撒谎给你要优于keySet,这一种也是最常用的遍历方法。

@Test
public void testEntry(){
    for (Map.Entry<Integer,Integer> entry: map.entrySet()){
        System.out.println(entry.getKey()+":"+entry.getValue());
    }
}

六、Iterator方式遍历map

对于上面的foreach都可以用Iterator在Java5中才被支持,foreach的写法看起来更简洁。但Iterator也有优势:在用foreach遍历map时,如果改变其大小,会报错,但如果只是删除元素,可以使用Iterator的remove方法删除元素。

//Iterator entrySet获取key和value
    public void testIterator(){
        Iterator<Map.Entry<Integer,Integer>> it = map.entrySet().iterator();
        while (it.hasNext()){
            Map.Entry<Integer,Integer> entry = it.next();
            System.out.println(entry.getKey()+":"+ entry.getValue());
            it.remove();//删除元素
        }
    }

七、Lambda表达式

java8提供了Lambda表达式支持,语法看起来更简洁,可以同时拿到key和value,不过性能低于entrySet,所以更推荐entrySet的方式

public void testLambda(){
        map.forEach((key,value)->{
            System.out.println(key+":"+value);
        });
    }

总结

到此这篇关于Java遍历Map的5种方式的文章就介绍到这了,更多相关Java遍历Map内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文