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 }

java关于集合的遍历与增强for循环(foreach)的使用的更多相关文章

  1. “全栈2019”Java第三十二章:增强for循环Foreach语法

    难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java第 ...

  2. Java自学-集合框架 遍历

    遍历ArrayList的三种方法 步骤 1 : 用for循环遍历 通过前面的学习,知道了可以用size()和get()分别得到大小,和获取指定位置的元素,结合for循环就可以遍历出ArrayList的 ...

  3. Java之集合的遍历与迭代器

    集合的遍历 依次获取集合中的每一个元素 将集合转换成数组,遍历数组 //取出所有的学号, 迭代之后显示学号为1004-1009 Object[] c=map.keySet().toArray();// ...

  4. 集合、迭代器、增强for循环、泛型

    1集合 集合是java中提供的一种容器,可以用来存储多个数据. 数组的长度是固定的.集合的长度是可变的.集合中存储的元素必须是引用类型数据. 1.1ArrayList集合存储元素(复习) 例: pub ...

  5. Java中的增强 for 循环 foreach

    foreach 是 Java 中的一种语法糖,几乎每一种语言都有一些这样的语法糖来方便程序员进行开发,编译期间以特定的字节码或特定的方式来对这些语法进行处理.能够提高性能,并减少代码出错的几率.在 J ...

  6. Java基础系列(24)- 增强for循环

    增强for循环 这里我们先只是见一面,做个了解,之后数组部分会重点使用 Java5引入了一种主要用于数组或集合的增强型for循环 Java增强for循环语法格式如下 for(声明语句:表达式){ // ...

  7. Java SE 枚举,注解,增强for循环

    Java SE 进阶 1.Enum 枚举对象名通常使用全部大写,常量的命名规范 构造器私有化 本类内部创建一组对象 对外暴露对象(通过为对象添加 public final static 修饰符) 可以 ...

  8. 增强for循环 -- foreach循环

    1  作用 简化迭代器的书写格式.(注意:foreach循环的底层还是使用了迭代器遍历.) 2  适用范围 如果是实现了Iterable接口的对象或者是数组对象都可以使用foreach循环. 3  格 ...

  9. 【Java】 二叉树的遍历(递归与循环+层序遍历)

    在[Java] 大话数据结构(9) 树(二叉树.线索二叉树)一文中,已经实现了采用递归方法的前.中.后序遍历,本文补充了采用循环的实现方法.以及层序遍历并进行了一个总结. 递归实现 /* * 前序遍历 ...

随机推荐

  1. vs2015多行注释与取消多行注释

    注释: 先CTRL+K,然后CTRL+C 取消注释: 先CTRL+K,然后CTRL+U

  2. zookeeper在搭建的时候,解决后台启动为standalone模式问题

    今天在搭建zookeeper,搭建完成之后,启动一直报错: 上网查了好多资料:有几种解决方案: 1.在配置文件conf目录下,将zoo_sample.cfg删除,只留zoo.cfg(然而就我的情况而言 ...

  3. 基于Struts2框架的文件下载 --- Struts2

    一.Struts2指定类型文件的下载 1.最终功能实现的截图:(点击文件下载链接,下载文件 ) 2.核心代码 index.jsp: <%@ page language="java&qu ...

  4. MP4介绍与基本AVC编码(x264)教程

    MP4介绍与基本AVC编码(x264)教程(最后更新: 2006.03.25)为日益增加的对MP4 H264/AVC编码的需求,本人做了一个简单的MP4介绍与基本AVC编码(使用x264)教程最后更新 ...

  5. 6.4 操作契约 Operation Contracts

    4.操作契约 Operation Contracts  “用例描述”的补充  强调: 用例中重要的动作,其开始与结束是需要一些约束 4.5 操作契约的后置条件  定义Definition  后 ...

  6. [pat]数素数

    时间限制:1000 ms 内存限制 32768 KB 代码长度限制 100 KB 判断程序 Standard (来自 小小) 题目描述 令Pi表示第i个素数.现任给两个正整数M <= N < ...

  7. 海康摄像头配置固定IP

    前言 首先要海康设备连接好网线,电脑客户端跟海康设备在同一个局域网络. 1.直接在海康网站下载SADP工具软件,安装SADP工具,如图所示: 2.安装成功后,桌面的出现设备网络搜索, 面板介绍:这里将 ...

  8. ubuntu Sublime Text 2编辑器安装

    官网下载http://www.sublimetext.com/2 选择合适的包下载回来的格式是.tar.bz2格式,需要进行解压. 1,解压:tar -xvf Sublime\ Text\ 2.0.2 ...

  9. leetcode-algorithms-2 Add Two Numbers

    leetcode-algorithms-2 Add Two Numbers You are given two non-empty linked lists representing two non- ...

  10. BIO,NIO的区别,使用场景。

    一.什么是io? i就是input,输入,o就是output,输出,合起来就是以流为基本的输入输出. 二.传统的io 传统的服务器端同步阻塞I/O处理(也就是BIO,Blocking I/O): 当客 ...