Java中List、Map、Set的遍历方式

来源:互联网 发布:辽宁省软件协会 编辑:程序博客网 时间:2024/06/15 15:12

一、List的遍历

1.迭代器遍历

List<String> list=new ArrayList<String>();Iterator<String> iter = list.iterator();while(iter.hasNext()){      System.out.println(iter.next());}

这种方式在循环执行过程中会进行数据锁定,性能稍差, 同时,如果你想在寻欢过程中去掉某个元素,只能调用it.remove方法, 不能使用list.remove方法, 否则一定出现并发访问的错误。

2.增强for循环

List<String> list=new ArrayList<String>();for(String str:list){    System.out.println(str);}

最简单的遍历写法,其内部实质上还是调用了迭代器遍历方式,这种循环方式还有其他限制,不建议使用

3.普通for循环

List<String> list=new ArrayList<String>();for( int i = 0 ; i < list.size() ; i++) {    System.out.println(list.get(i));}

内部不锁定,效率最高,但在多线程要考虑并发操作的问题。

二、Map的遍历

1.for-each循环中使用entry来遍历

Map<String, String> map = new HashMap<String, String>();  for (Map.Entry<String, String> entry : map.entrySet()) {      System.out.println("Key = " + entry.getKey() + ", Value = " + entry.getValue());  }  

这是最常见的并且在大多数情况下也是最可取的遍历方式。在键值都需要时使用。但是需要注意的是,如果你遍历的是一个空的map对象,for-each循环将抛出NullPointerException,因此在遍历前你总是应该检查空引用。

2.for-each循环中遍历keys或values

Map<String, String> map = new HashMap<String, String>();  //遍历map中的键  for (String key : map.keySet()) {      System.out.println("Key = " + key);  }  //遍历map中的值  for (String value : map.values()) {      System.out.println("Value = " + value);  }  

如果只需要map中的键或者值,你可以通过keySet或values来实现遍历,而不是用entrySet。该方法比entrySet遍历在性能上稍好(快了10%),而且代码更加干净。

3.使用Iterator遍历

Map<String, String> map = new HashMap<String, String>();  Iterator<Map.Entry<String, String>> entries = map.entrySet().iterator();  while (entries.hasNext()) {      Map.Entry<String, String> entry = entries.next();      System.out.println("Key = " + entry.getKey() + ", Value = " + entry.getValue());  }  

该种方式看起来冗余却有其优点所在。首先,在老版本java中这是惟一遍历map的方式。另一个好处是,你可以在遍历时调用iterator.remove()来删除entries,另两个方法则不能。
从性能方面看,该方法类同于for-each遍历(即方法二)的性能。

4.通过键找值遍历

Map<String, String> map = new HashMap<String, String>();  for (Stringkey : map.keySet()) {      Stringvalue = map.get(key);      System.out.println("Key = " + key + ", Value = " + value);  }  

这个代码看上去更加干净,但实际上它相当慢且无效率。因为从键取值是耗时的操作。所以尽量避免使用。

三、Set的遍历

1.Iterator迭代器遍历

Set<String> set=new HashSet<String>();Iterator<String> itr = set.iterator();    while(itr.hasNext()){        String str = itr.next();        System.out.println(str);    }

2.通过增强型for循环遍历

Set<String> set=new HashSet<String>();for (String str : set) {        System.out.println(str);    }
0 0
原创粉丝点击