一、集合的输出

迭代输出:Iteratror接口

在输出集合时,最标准的方法是使用迭代器迭代输出。

1,List中的迭代器。

Iterator中包含三个方法:

hasNex()t判断集合内是否有元素存在。

next()返回当前元素,并让游标指向下一元素。

remove删除next返回的当前元素。

我们首先来看前两个方法。

import java.util.ArrayList;
import java.util.Iterator;
import java.util.List; public class TestIte {
public static void main(String[] args) {
List <Integer>l = new ArrayList<>();
l.add(1);
l.add(2);
l.add(3);
Iterator ite = l.iterator();//调用iterator实例化一个迭代器对象。
while(ite.hasNext()){    //判断集合中是否有元素
System.out.println(ite.next());//返回当前元素,并让游标指向下一元素。
}
}
}
运行结果:
1
2
3

我们来看l.iterator这句,这句调用的是ArratList中的iterator方法。

它会返回一个迭代器对象。

我么再来看Itr中的内容。

Itr作为一个内部类,并且实现了Iterator接口。

我们来看下Itr类里面的两个变量:

cursor就是游标,由于它在一个私有类中默认为0,

lastRet就是删除时指定的元素。

首先我们来看下里面的hasNext()方法:

多么的简单,就一个判断,判断cursor是否等于数组元素个数。

我们来看第二个next():

首先将cursor给i,然后判断下是否大于数组元素个数,大于则抛出异常。

然后创建一个Object数组,将存储ArrayList元素的数组缓冲区给Object数组。(数组缓冲区的长度是这个ArrayList的容量),大于就抛出异常。

将cursor向后移动一位,返回数组中的第i个元素,并将i给lastRet。

最后我们来看下remove():

如果lastRet小于0则抛异常,删除数组中第lastRet个元素。

然后将lastRet给cursor(删除元素后游标要向前挪动一位,所以讲lastRet给cursor)

举个例子,例如此时cursor=2,则lastRet=1,如果我删除了第1个元素,那么这时第2个元素就挪到第1个元素的位置了,

cursor之前指向的第二个元素其实是删除后的第一个元素。

然后将lastRet变成-1,所以如果两次连续的使用remove()会出现错误,因为第二次使用时lastRet还没有被cursor赋值。

2.Set集合的输出

Set与上面的List类似,基本方法没有太大差别;

import java.util.ArrayList;
import java.util.HashSet;
import java.util.Iterator;
import java.util.List;
import java.util.Set; public class TestIte {
public static void main(String[] args) {
Set <Integer>l = new HashSet<>();
l.add();
l.add();
l.add();
Iterator ite = l.iterator();
while(ite.hasNext()){//判断集合中是否有元素
System.out.println(ite.next());
}
}
}
运行结果:
1
2
3

3.Map集合的输出

Map中存放的是一对值K,V,而迭代器每次只能找到一个值,所有如果要用迭代器输出Map的话需要按一下步骤。

1.Map对象调用entruSet()方法,返回一个Set对象。

2.用Set实例化一个Iterator

3.通过Map.entry进行K,V分离。

import java.util.ArrayList;
import java.util.HashMap;
import java.util.HashSet;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import java.util.Map.Entry;
import java.util.Set; public class TestIte {
public static void main(String[] args) {
Map <Integer,String>m = new HashMap<>();
m.put(1, "A");
m.put(2, "B");
m.put(3, "C");
Set<Map.Entry<Integer, String>> sm = m.entrySet();//调用entrySet方法变为Set对象,该方法返回值是Set<Map.Entry<K,V>>
Iterator<Map.Entry<Integer, String>> mite = sm.iterator();//为转化为Set的Map,实例化迭代器
while(mite.hasNext()){//判断集合中是否有元素
Map.Entry<Integer, String> mo = mite.next();//将取出的值转换为Map.Entry
System.out.println(mo.getKey() + mo.getValue());//调用Map.Entry中的方法,取得K,V的值
}
}
}
运行结果:
1A
2B
3C

entrySet返回一个Set<Map.Entru<K,V>>.

Map.Entry是Map内部定义的一个接口,专门用来保存key-value的值。

Map.Entry接口中定义了获取K,V的方法。

可以这样理解,把K,V想象成两个小盒子,Map.Entry就是放两个小盒子的大盒子。

一开始将装K,V的小盒子的大盒子Map.Entry作为一个类型,放入Set中,这时把K,V看出一个整体。

然后通过Set的迭代器来实现输出,输出时又将其转换为Map.Entry,然后取出K,V。

5.3类集(java学习笔记)集合的输出的更多相关文章

  1. java学习笔记—集合之Map集合

    p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; text-align: center; font: 12.0px Times } p.p2 { margin: 0.0p ...

  2. Java学习笔记——集合

    类集简介 从JDK1.2开始Java引入了类集开发框架,所谓的类集指的就是一套动态对象数组的实现方案,在实际开发之中没有有何一项开发可以离开数组,但是传统的数组实现起来非常的繁琐.而且长度是其致命伤, ...

  3. java学习笔记 --- 集合(续)

    1.map集合 1.1.特点:将键映射到值的对象.一个映射不能包含重复的键:每个键最多只能映射到一个值. 1.2.Map集合和Collection集合的区别? Map集合存储元素是成对出现的,Map集 ...

  4. 0015 Java学习笔记-集合-TreeMap集合

    主要的方法 构造方法: TreeMap(); TreeMap(Comparator<?super K> comparator); TreeMap(Map<? extends K,? ...

  5. 0014 Java学习笔记-集合-HashMap集合

    主要的方法 + 构造方法: * HashMap(); - 默认大小16,负载因子0.75 * HashMap(int initialCapacity); * HashMap(int initialCa ...

  6. Java学习笔记--集合元素的比较Comparable,Comparator

    原文见: http://www.cnblogs.com/sunflower627/p/3158042.html 1. Comparator 和 Comparable 相同的地方 他们都是java的一个 ...

  7. java学习笔记 --- 集合

    1.定义:集合是一种容器,专门用来存储对象 数组和集合的区别?   A:长度区别  数组的长度固定 集合长度可变 B:内容不同  数组存储的是同一种类型的元素  而集合可以存储不同类型的元素  C:元 ...

  8. java学习笔记-集合set

    equals指内容(值)相等,== 指地址相等 ===============set类 set继承自collection,但set没有新增方法,只是set里的元素不重复,下面是set常用方法 ==== ...

  9. 3.3常用类(java学习笔记)Runtime与Process

    一.Runtime 我们来看下文档中对Runtime的说明: 每一个java程序都有一个属于Runtime类的实例,它允许程序连接到程序运行环境. 当前runtime可以用getRuntime()方法 ...

  10. 3.2常用类(java学习笔记)String与StringBuffer

    一.String String又称不可变字符序列. 我们看JDK源码中用于字符存储的数组有final修饰,final修饰变量就代表变量不能改变. 我们可以看API文档中对String的描述. Stri ...

随机推荐

  1. Substrings Sort string 基本操作

    You are given nn strings. Each string consists of lowercase English letters. Rearrange (reorder) the ...

  2. apply()和call()

    每个函数都包含俩个非继承而来的方法:apply() 和 call(),这俩个方法的用途都是在特定的作用域中调用函数,实际上等于设置函数体内this对象的值,以扩充函数赖以运行的作用域.一般来讲,thi ...

  3. mysql5.7.11安装遇到的问题

    首次安装mysql5.7.11绿色版,真是破费功夫,现记录安装中遇到的问题,只是解决了问题,而不清楚问题的由来. 问题一: 问题二: 问题三: 问题四: 我的my.ini配置文件: [mysql] # ...

  4. 【洛谷 P1251】 餐巾计划问题 (费用流)

    题目链接 我做的网络流24题里的第一题.. 想是不可能想到的,只能看题解. 首先,我们拆点,将一天拆成晚上和早上,每天晚上会受到脏餐巾(来源:当天早上用完的餐巾,在这道题中可理解为从原点获得),每天早 ...

  5. NYOJ 115 城市平乱 (最短路)

    * 题目链接* 描述 南将军统领着N个部队,这N个部队分别驻扎在N个不同的城市. 他在用这N个部队维护着M个城市的治安,这M个城市分别编号从1到M. 现在,小工军师告诉南将军,第K号城市发生了暴乱,南 ...

  6. win8优化

    微软发布win8系统之后受到很多电脑爱好者的关注,都想去尝试体验win8操作系统,对电脑系统优化和系统性能提高一直是我们所追求的.而很多用户都会选择第三方软件对系统进行相关优化,其实我们可以手动对电脑 ...

  7. [Leetcode Week8]Subsets

    Subsets 题解 原创文章,拒绝转载 题目来源:https://leetcode.com/problems/subsets/description/ Description Given a set ...

  8. python学习笔记 async and await

    用asyncio提供的@asyncio.coroutine可以把一个generator标记为coroutine类型,然后在coroutine内部用yield from调用另一个coroutine实现异 ...

  9. 如何在Ubuntu 16.04安装的Git【转】

    转自:https://www.howtoing.com/how-to-install-git-on-ubuntu-16-04/ 介绍 现代软件开发中不可或缺的工具是某种版本控制系统. 版本控制系统允许 ...

  10. ggplot2绘制多图

    参考链接:http://www.cnblogs.com/nxld/p/6065237.html ggplot2.multiplot是一个易于使用的功能,将多个图形在同一页面上使用R统计软件和GGPLO ...