Java SE之For增强与Iterator遍历器提取数据(附Map.Entry)
增强for循环:
1.操作数组
2.操作List集合
3.操作Map集合
1.map.values()法
2.map.keySet()法 【传统方法】
3.Map.Entry法 【新颖方法:增强for+map.entrySet()+Map.Entry】
Iterator遍历器:
操作Map集合:
1.map.keySet()法【传统】
2.Entry法 【新颖 Set+Iterator+Map.Entry】
---------------------------------------------------------------------
import Java.util.List;
import java.security.KeyStore.Entry;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.Iterator;
import java.util.LinkedHashMap;
import java.util.LinkedList;
import java.util.Map;
import java.util.Set;
import org.junit.Assert;
import org.junit.Test;
public class DemoTest {
/*
* 增强for循环
* 注意:增强for只适合取数据,
* 并不能通过遍历变量(相当于指针的作用)去改变集合/数组内的元素。
* */
@Test
public void testFor(){
//1.操作数组
int arr[]={6,1,3,8};
for(int num:arr)
System.out.println(num);
System.out.println("-------操作数组-------");
//2.操作List集合
List list = new ArrayList();
list.add("82242");
list.add("24235");
list.add("65734");
for( Object obj:list)
System.out.println(obj);
System.out.println("-----操作List集合------");
//3.操作Map集合
//注意:LinkedHashMap 按照正向顺序取出
// HashMap 按照逆向顺序取出
Map map = new LinkedHashMap();
map.put(3535,"set");
map.put(1324,"FHdg");
map.put(35,"rehhg");
// map.values()法 //仅仅只可以取出 值
for(Object obj:map.values())
System.out.println("value:"+obj);
System.out.println("------操作Map--map.values()法-----");
// map.keySet()法 【传统方法】
for(Object obj:map.keySet()){
System.out.println("Key:"+(int)obj+" Value:"+map.get((int)obj));
}
System.out.println("------操作Map--map.keySet()法-----");
//Map.Entry法 【新颖方法:增强for+entrySet()+Map.Entry】
for(Object obj:map.entrySet()){
Map.Entry entry = (Map.Entry) obj;
System.out.println("Key:"+entry.getKey()+" Value:"+entry.getValue());
}
System.out.println("------操作Map--Map.Entry法 -----");
System.out.println("for-----------");
}
/*
* 传统方式: Iterator遍历器
* */
@Test
public void testIterator(){
Map map = new LinkedHashMap();
map.put(3535,"set");
map.put(1324,"FHdg");
map.put(35,"rehhg");
//map.keySet()法【传统】
Set set = map.keySet();
Iterator iterator = set.iterator();
while(iterator.hasNext()){
int key = (int) iterator.next();
System.out.println("Key:"+key+" Value:"+map.get(key));
}
//Entry法 【新颖 Set+Iterator+Map.Entry】
//可以用Map.Entry+iterator遍历器分别地取Map.Entry集合内的Key和Value
while(iterator.hasNext()){
// System.out.print(iterator.next()); //会依次输出一次输出一对键值对 :686=dgd 980=uydg 324=tere
Map.Entry entry = (Map.Entry) iterator.next();
int key = (int) entry.getKey();
String value = (String) entry.getValue();
System.out.println("Key:"+key+" Value:"+value);
}
System.out.println("iterator-----------");
}
}
OutPut:============================================================
6
1
3
8
-------操作数组-------
82242
24235
65734
-----操作List集合------
value:set
value:FHdg
value:rehhg
------操作Map--map.values()法-----
Key:3535 Value:set
Key:1324 Value:FHdg
Key:35 Value:rehhg
------操作Map--map.keySet()法-----
Key:3535 Value:set
Key:1324 Value:FHdg
Key:35 Value:rehhg
------操作Map--Map.Entry法 -----
for-----------
Key:3535 Value:set
Key:1324 Value:FHdg
Key:35 Value:rehhg
iterator-----------
Java SE之For增强与Iterator遍历器提取数据(附Map.Entry)的更多相关文章
- 疑问:Iterator 遍历器和数据集合各种遍历方法的区别
https://es6.ruanyifeng.com/#docs/iterator Iterator(遍历器)的概念 Iterator 接口主要供for...of消费 Iterator 的遍历过程是: ...
- 8.2.2 使用Java8增强的Iterator遍历集合元素
8.2.2 使用Java 8增强的Iterator遍历集合元素 Iterator接口方法 程序示例 Iterator仅用于遍历集合 Iterator必须依附于Collection对象 修改迭代变量的值 ...
- ES6的 Iterator 遍历器到底是什么?
这节课要讲的是ES6中的Iterator. for...of为啥不遍历Object对象 第十三节我们讲了简单又实用的for...of,我们可以使用它来遍历数组,字符串,Set和Map结构,但是有没有发 ...
- Java SE 8 并发增强
1.原子值 java5开始,提供了一些原子操作的类,如AtomicInteger.AtomicLong等 这些类提供了诸如incrementAndGet这样的原子操作方法. 单数如果想进行复杂操作,则 ...
- Iterator遍历器 调用Symbol.Iterator属性,遍历器对象。
Iterator实现原理 创建一个指针对象,指向当前数据结构的起始位置.也就是说,遍历器对象本质上,就是一个指针对象. 第一次调用指针对象的next方法,可以将指针指向数据结构的第一个成员. 第二次调 ...
- ES6的Iterator遍历器
JS表示集合的对象主要有Array.Set.Object.Map,在以前,遍历它们需要使用2种不同的方法,而现在,JS提出了Iterator机制,可以给不同的数据结构提供统一的遍历方法,就是for…o ...
- Iterator 遍历器
1.遍历器(Iterator)是一种接口,为各种不同的数据结构提供统一的访问机制.任何数据结构只要部署Iterator接口,就可以完成遍历操作(即依次处理该数据结构的所有成员). 2.Iterator ...
- ES6学习笔记(十三)Iterator遍历器和for...of循环
1.概念 遍历器(Iterator)就是这样一种机制.它是一种接口,为各种不同的数据结构提供统一的访问机制.任何数据结构只要部署 Iterator 接口,就可以完成遍历操作(即依次处理该数据结构的所有 ...
- java8 增强的Iterator遍历集合元素
Iterator接口也是Java集合框架的成员,与Collection和Map两个系列的集合不一样的是Collection和Map系列主要用于充当容器的作用,而Iterator正如其名字一样是主要用于 ...
随机推荐
- 设计模式笔记:策略模式(Strategy)
1. 策略模式简介 1.1 定义 策略是为达到某一目的而采取的手段或方法,策略模式的本质是目标与手段的分离,手段不同而最终达成的目标一致.客户只关心目标而不在意具体的实现方法,实现方法要根据具体的环境 ...
- Bootstrap插件概述
前面的话 Bootstrap除了包含丰富的Web组件之外,如下拉菜单.按钮组.导航.分页等,还包括一些JavaScript的插件.插件为 Bootstrap 的组件赋予了“生命”.Bootstrap的 ...
- Bootstrap缩略图
前面的话 缩略图在网站中最常用的地方就是产品列表页面,一行显示几张图片,有的在图片底部(左侧或右侧)带有标题.描述等信息.Bootstrap框架将这一部独立成一个模块组件,本文将详细介绍Bootstr ...
- maven 聚合的含义是父类打包 ,清理等 则子类自动打包;也就是一键打包 方便服务
maven 聚合的含义是父类打包 ,清理等 则子类自动打包:也就是一键打包 方便服务
- BZOJ3786星系探索——非旋转treap(平衡树动态维护dfs序)
题目描述 物理学家小C的研究正遇到某个瓶颈. 他正在研究的是一个星系,这个星系中有n个星球,其中有一个主星球(方便起见我们默认其为1号星球),其余的所有星球均有且仅有一个依赖星球.主星球没有依赖星球. ...
- BZOJ4998星球联盟——LCT+并查集(LCT动态维护边双连通分量)
题目描述 在遥远的S星系中一共有N个星球,编号为1…N.其中的一些星球决定组成联盟,以方便相互间的交流.但是,组成 联盟的首要条件就是交通条件.初始时,在这N个星球间有M条太空隧道.每条太空隧道连接两 ...
- BZOJ1127 POI2008KUP(悬线法)
首先显然地,如果某个格子的权值超过2k,其一定不在答案之中:如果在[k,2k]中,其自身就可以作为答案.那么现在我们只需要考虑所选权值都小于k的情况. 可以发现一个结论:若存在一个权值都小于k的矩阵其 ...
- JavaScript实现表单的全选,反选,获取值
构思 通过for循环和for in循环来实现,界面效果如下 步骤 全选: 循环给所有的表单设置checked 反选: 循环内判断checked是否为true,如果为true则改为false否则改为tr ...
- 博弈论基础知识: 巴什博奕+斐波那契博弈+威佐夫博奕+尼姆博弈(及Staircase)(转)
(一)巴什博奕(Bash Game):只有一堆n个物品,两个人轮流从这堆物品中取物,规定每次至少取一个,最多取m个.最后取光者得胜.若(m+1) | n,则先手必败,否则先手必胜.显然,如果n=m+1 ...
- java 按概率产生
import java.util.Random; import org.junit.Test; public class Demo1 { public void getChance(int perce ...