java关于集合的遍历与增强for循环(foreach)的使用

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)的使用的更多相关文章
- “全栈2019”Java第三十二章:增强for循环Foreach语法
难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java第 ...
- Java自学-集合框架 遍历
遍历ArrayList的三种方法 步骤 1 : 用for循环遍历 通过前面的学习,知道了可以用size()和get()分别得到大小,和获取指定位置的元素,结合for循环就可以遍历出ArrayList的 ...
- Java之集合的遍历与迭代器
集合的遍历 依次获取集合中的每一个元素 将集合转换成数组,遍历数组 //取出所有的学号, 迭代之后显示学号为1004-1009 Object[] c=map.keySet().toArray();// ...
- 集合、迭代器、增强for循环、泛型
1集合 集合是java中提供的一种容器,可以用来存储多个数据. 数组的长度是固定的.集合的长度是可变的.集合中存储的元素必须是引用类型数据. 1.1ArrayList集合存储元素(复习) 例: pub ...
- Java中的增强 for 循环 foreach
foreach 是 Java 中的一种语法糖,几乎每一种语言都有一些这样的语法糖来方便程序员进行开发,编译期间以特定的字节码或特定的方式来对这些语法进行处理.能够提高性能,并减少代码出错的几率.在 J ...
- Java基础系列(24)- 增强for循环
增强for循环 这里我们先只是见一面,做个了解,之后数组部分会重点使用 Java5引入了一种主要用于数组或集合的增强型for循环 Java增强for循环语法格式如下 for(声明语句:表达式){ // ...
- Java SE 枚举,注解,增强for循环
Java SE 进阶 1.Enum 枚举对象名通常使用全部大写,常量的命名规范 构造器私有化 本类内部创建一组对象 对外暴露对象(通过为对象添加 public final static 修饰符) 可以 ...
- 增强for循环 -- foreach循环
1 作用 简化迭代器的书写格式.(注意:foreach循环的底层还是使用了迭代器遍历.) 2 适用范围 如果是实现了Iterable接口的对象或者是数组对象都可以使用foreach循环. 3 格 ...
- 【Java】 二叉树的遍历(递归与循环+层序遍历)
在[Java] 大话数据结构(9) 树(二叉树.线索二叉树)一文中,已经实现了采用递归方法的前.中.后序遍历,本文补充了采用循环的实现方法.以及层序遍历并进行了一个总结. 递归实现 /* * 前序遍历 ...
随机推荐
- linux下python操作的一些命令
1.查看python当前版本以及安装路径 [root@localhost bin]# python -V Python [root@localhost HMK]# whereis python pyt ...
- GEO数据下载分析(SRA、SRR、GEM、SRX、SAMN、SRS、SRP、PRJNA全面解析)
很多时候我们需要从GEO(https://www.ncbi.nlm.nih.gov/geo/)下载RNA-seq数据,一个典型的下载页面是https://www.ncbi.nlm.nih.gov/ge ...
- mandatory and advisory文件锁(File Lock)
http://blog.csdn.net/elfprincexu/article/details/43564425 文件锁(File Lock)是一种在特定的时间内只允许一个进程进行访问文件的机制,通 ...
- 51Nod 1810 连续区间
https://www.51nod.com/onlineJudge/questionCode.html#!problemId=1810 题目给出一个1~n的排列,问有多少连续区间.连续区间的定义为区间 ...
- Two Melodies CodeForces - 813D (DP,技巧)
https://codeforces.com/problemset/problem/813/D dp[i][j] = 一条链以i结尾, 另一条链以j结尾的最大值 关键要保证转移时两条链不能相交 #in ...
- 整体二分求动态区间第k大
比树状数组套主席树不知道高到哪里去了,solve(l,r,L,R)就是对于L,R的操作区间的答案都在l,r区间里,然后递归下去 复杂度O(nlognlogn),每个操作会执行logn次就是o(nlog ...
- Spring缓存注解
从3.1开始,Spring引入了对Cache的支持.其使用方法和原理都类似于Spring对事务管理的支持.Spring Cache是作用在方法上的,其核心思想是这样的:当我们在调用一个缓存方法时会把该 ...
- stl常用的查找算法
#include<iostream> using namespace std; #include"vector" #include"algorithm&quo ...
- win 安装plsql的步骤
1.下载oracle和plsql地址:http://pan.baidu.com/s/1bTlcom,http://pan.baidu.com/s/1c2BMsZe 2.首先安装plsql 这个比较简单 ...
- [洛谷 P2709] 小B的询问
P2709 小B的询问 题目描述 小B有一个序列,包含N个1~K之间的整数.他一共有M个询问,每个询问给定一个区间[L..R],求Sigma(c(i)^2)的值,其中i的值从1到K,其中c(i)表示数 ...