zoukankan      html  css  js  c++  java
  • java关于集合的遍历与增强for循环(foreach)的使用

     java集合类的使用可以说是无处不在,总的我们可以将之分为三大块,分别是从Collection接口延伸出的List、Set和以键值对形式作存储的Map类型集合。
         许多情况需要我们遍历出集合中的元素,并做相应的处理。
         下面对各种类型的集合的遍历做一些总结,关于增强for循环,需要注意的是,使用增强for循环无法访问数组下标值,对于集合的遍历其内部采用的也是Iterator的相关方法。如果只做简单遍历读取,增强for循环确实减轻不少的代码量。
    关于List与Set类型集合的遍历:
    复制代码
     1 import java.util.ArrayList;
     2 import java.util.HashSet;
     3 import java.util.Iterator;
     4 import java.util.List;
     5 import java.util.Set;
     6 
     7 public class ListAndSetTest {
     8 
     9     public static void main(String[] args) {
    10         // List集合的遍历
    11         listTest();
    12         // Set集合的遍历
    13         setTest();
    14     }
    15 
    16     private static void setTest() {
    17         Set<String> set = new HashSet<String>();
    18         set.add("JAVA");
    19         set.add("C");
    20         set.add("C++");
    21         // 重复的加不进去。
    22         set.add("JAVA");
    23         set.add("JAVASCRIPT");
    24 
    25         //set集合遍历方法1,使用iterator
    26         Iterator<String> it = set.iterator();
    27         while (it.hasNext()) {
    28             String value = it.next();
    29             System.out.println(value);
    30         }
    31         
    32         //set集合遍历方法2,使用增强for循环。
    33         for(String s: set){
    34             System.out.println(s);
    35         }
    36     }
    37 
    38     // 遍历list集合
    39     private static void listTest() {
    40         List<String> list = new ArrayList<String>();
    41         list.add("java111");
    42         list.add("java222");
    43         list.add("java333");
    44         list.add("java444");
    45         list.add("java555");
    46 
    47         // 遍历方式1 ,使用iterator
    48         Iterator<String> it = list.iterator();
    49         while (it.hasNext()) {
    50             String value = it.next();
    51             System.out.println(value);
    52         }
    53 
    54         // 遍历方法2 , 使用传统for循环进行遍历。
    55         for (int i = 0, size = list.size(); i < size; i++) {
    56             String value = list.get(i);
    57             System.out.println(value);
    58         }
    59 
    60         // 遍历方法3 , 使用增强for循环进行遍历。
    61         for (String value : list) {
    62             System.out.println(value);
    63         }
    64     }
    65 }
    复制代码

    关于Map类型集合的遍历,keySet()与entrySet()方法:

    复制代码
     1 //增强For循环
     2 public class MapTest {
     3 
     4     public static void main(String[] args) {
     5         // 创建一个HashMap对象,并加入了一些键值对。
     6         Map<String, String> maps = new HashMap<String, String>();
     7         maps.put("111", "java111");
     8         maps.put("222", "java222");
     9         maps.put("333", "java333");
    10         maps.put("444", "java444");
    11         maps.put("555", "java555");
    12         
    13         // 传统的遍历map集合的方法1; keySet()
    14         //traditionalMethod1(maps);
    15         // 传统的遍历map集合的方法2; entrySet()
    16         //traditionalMethod2(maps);
    17         // 使用增强For循环来遍历map集合方法1; keySet()
    18         //strongForMethod1(maps);
    19         // 使用增强For循环来遍历map集合方法2; entrySet()
    20         strongForMethod2(maps);
    21     }
    22 
    23     private static void strongForMethod2(Map<String, String> maps) {
    24         Set<Entry<String, String>> set = maps.entrySet();
    25         for (Entry<String, String> entry : set) {
    26             String key = entry.getKey();
    27             String value = entry.getValue();
    28             System.out.println(key + " : " + value);
    29         }
    30     }
    31 
    32     private static void strongForMethod1(Map<String, String> maps) {
    33         Set<String> set = maps.keySet();
    34         for (String s : set) {
    35             String key = s;
    36             String value = maps.get(s);
    37             System.out.println(key + " : " + value);
    38         }
    39     }
    40 
    41     // 使用entrySet()方法,获取maps集合中的每一个键值对,
    42     private static void traditionalMethod2(Map<String, String> maps) {
    43         Set<Map.Entry<String, String>> sets = maps.entrySet();
    44         // 取得迭代器遍历出对应的值。
    45         Iterator<Entry<String, String>> it = sets.iterator();
    46         while (it.hasNext()) {
    47             Map.Entry<String, String> entry = (Entry<String, String>) it.next();
    48             String key = entry.getKey();
    49             String value = entry.getValue();
    50             System.out.println(key + " : " + value);
    51         }
    52     }
    53 
    54     // 使用keySet()方法,获取maps集合中的所有键,遍历键取得所对应的值。
    55     private static void traditionalMethod1(Map<String, String> maps) {
    56         Set<String> sets = maps.keySet();
    57         // 取得迭代器遍历出对应的值。
    58         Iterator<String> it = sets.iterator();
    59         while (it.hasNext()) {
    60             String key = it.next();
    61             String value = maps.get(key);
    62             System.out.println(key + " : " + value);
    63         }
    64     }
    65 }
    复制代码
  • 相关阅读:
    我的2018:OCR、实习和秋招
    【OCR技术系列之六】文本检测CTPN的代码实现
    【OCR技术系列之五】自然场景文本检测技术综述(CTPN, SegLink, EAST)
    如何免费使用谷歌搜索
    CUDA编程之快速入门
    我在北京实习的四个月
    在C++98基础上学习C++11新特性
    Linux编程之线程池的设计与实现(C++98)
    ASP.NET Core中使用IOC三部曲(三.采用替换后的Autofac来实现AOP拦截)
    ASP.NET Core文件上传与下载(多种上传方式)
  • 原文地址:https://www.cnblogs.com/Pjson/p/8419663.html
Copyright © 2011-2022 走看看