迭代器的作用是提供一种方法对一个容器对象中的各个元素进行访问,而又不暴露该对象容器的内部细节。

java中的很多容器都实现了Iterable接口,容器中的元素都是可以遍历的。

如下例,list容器中存储的是Integer对象,list可以返回一个Iterator对象用于遍历list中的元素。

        // list中存储的是Integer对象
List<Integer> list = Arrays.asList(1,2,3,4,5);
// 容器List实现了Iterable接口,也即实现了iterator()方法
// 该方法可以生成一个迭代器遍历list中的元素
Iterator<Integer> iterator = list.iterator();
// 使用迭代器iterator遍历list中的每一个元素,并打印出来
while(iterator.hasNext())
System.out.print(iterator.next() + " ");

一种更为简洁的写法是:

        // list中存储的是Integer对象
List<Integer> list = Arrays.asList(1,2,3,4,5);
// 遍历list中的每一个元素,并打印出来
for (int x:list)
System.out.print(x + " ");

迭代的实现

如果要写一个容器类,并使其具有迭代功能,该类应满足如下两个要求:

该类需继承Iterable接口,实现接口的iterator()方法;

定义一个实现Iterator接口的类,实现接口的hasNext()方法与next()方法。

如定义类Bag(背包)用于存储数据元素。

public class Bag<Item> {

    private class Node {
Item item;
Node next;
}
private Node first;
private int N; public boolean isEmpty() {return N==0;}
public int size() {return N;} public void add(Item item) {
Node temp = new Node();
temp.item = item;
temp.next = first;
first = temp;
} }

若要使容器Bag可迭代,Bag需要定义一个实现Iterator接口的类(BagIterator),该类中的hasNext()与next()方法可以帮助遍历元素。

    private class BagIterator implements Iterator<Item> {

        private Node current = first;
@Override
public boolean hasNext() {
return current != null;
}
@Override
public Item next() {
Item temp = current.item;
current = current.next;
return temp;
}
}

Bag需要实现Iterable接口,该接口的Iterator()方法,可以返回一个上述的迭代器(BagIterator)

public class Bag<Item> implements Iterable<Item>

    @Override
public Iterator<Item> iterator() {
return new BagIterator();
}

完整代码如下:

import java.util.Iterator;

public class Bag<Item> implements Iterable<Item>{

    private class Node {
Item item;
Node next;
}
private Node first;
private int N; public boolean isEmpty() {return N==0;}
public int size() {return N;} public void add(Item item) {
Node temp = new Node();
temp.item = item;
temp.next = first;
first = temp;
} private class BagIterator implements Iterator<Item> { private Node current = first;
@Override
public boolean hasNext() {
return current != null;
}
@Override
public Item next() {
Item temp = current.item;
current = current.next;
return temp;
}
} @Override
public Iterator<Item> iterator() {
return new BagIterator();
} }

测试如下:

    public static void main(String[] args) {

        Bag<Integer> bag = new Bag<>();
bag.add(3);
bag.add(2);
bag.add(3);
bag.add(1); for (int i:bag)
System.out.println(i);
}

输出结果:

1
3
2
3

java 迭代的更多相关文章

  1. 【转】Java迭代:Iterator和Iterable接口

    Java迭代 : Iterator和Iterable接口 从英文意思去理解 Iterable :故名思议,实现了这个接口的集合对象支持迭代,是可迭代的.able结尾的表示 能...样,可以做.... ...

  2. java迭代map

    java迭代map: import java.util.HashMap; import java.util.Iterator; import java.util.Map; import java.ut ...

  3. Java迭代 : Iterator和Iterable接口

    从英文意思去理解 Iterable :故名思议,实现了这个接口的集合对象支持迭代,是可迭代的.able结尾的表示 能...样,可以做.... Iterator:   在英语中or 结尾是都是表示 .. ...

  4. Java迭代实现斐波那契数列

    剑指offer第九题Java实现 题目: 大家都知道斐波那契数列,现在要求输入一个整数n,请你输出斐波那契数列的第n项. public class Test9 { public static void ...

  5. Java 迭代接口:Iterator、ListIterator 和 Spliterator

    1. 简介 当我们使用 for 或 while 循环来遍历一个集合的元素,Iterator 允许我们不用担心索引位置,甚至让我们不仅仅是遍历一个集合,同时还可以改变它.例如,你如果要删除循环中的元素, ...

  6. java 迭代的陷阱

    /** * 关于迭代器,有一种常见的误用,就是在迭代的中间调用容器的删除方法. * 但运行时会抛出异常:java.util.ConcurrentModificationException * * 发生 ...

  7. CoreJava(一)—— Java迭代语句

    本文介绍一些关于迭代语句的一些相关技巧以及Java8中的迭代语句的使用方法. public class TestBreak { public static void main(String[] arg ...

  8. SC || 关于java迭代中修改迭代集合的操作

    在通过for循环遍历整个List/Map等的时候,如果想要进行remove的操作,这时就更改了迭代集合,会出现错误 一种方法是如果只会remove一个可以remove后直接break 另一种是把集合先 ...

  9. 170530、java 迭代hashmap常用的三种方法

    @SuppressWarnings("rawtypes") public class HashMapDemo { //hashMap遍历 public static void ma ...

随机推荐

  1. bootstrap --- 在 modal中的 datetimepicker 关闭 ,会造成 modal也会被关闭.

    这个大概是事件冒泡造成的. 解决办法: <form id="userForm" class="form-horizontal"> <input ...

  2. 联想 Lenovo PWR-G60 无线掌中宝拆机

    从朋友那里弄了台Lenovo PWR-G60,现在已经停产了,淘宝上某店卖的国产WIFI Pineapple貌似就是拿这个刷的,打算出篇DIY教程 现在人在外地,编程器.热风枪.烙铁工具啥的都没有,更 ...

  3. wsgi&nginx-理解

    WSGI协议 首先弄清下面几个概念:WSGI:全称是Web Server Gateway Interface,WSGI不是服务器,python模块,框架,API或者任何软件,只是一种规范,描述web ...

  4. ubantu-vim操作

    vim其实就是vi的升级版,vi里的所有命令vim里都可以用,一般使用来说几乎没什么差别. 注:本篇文章区分大小写! vi / vim三级模式的关系: 命令行模式 任何时候,不管用户处于何种模式,只要 ...

  5. 使用golang编写prometheus metrics exporter

    metrcis输出 collector.go package main import ( "github.com/prometheus/client_golang/prometheus&qu ...

  6. 安装Cygwin,,以及遇到的问题

    实验需要用到Cygwin,于是去下了一个,安装过程比较顺利,参考:http://blog.csdn.net/chunleixiahe/article/details/55666792 但是发现  ma ...

  7. 在Microsoft Power BI中创建地图的10种方法

    今天,我们来简单聊一聊“地图”. 在我们日常生活中,地图地位已经提升的越来越高,出门聚餐.驾驶.坐车.旅行......应运而生的就是各种Map APP. 作为数据分析师,我们今天不讲生活地图,要跟大家 ...

  8. 索引rebuild与rebuild online区别

    索引rebuild与rebuild online区别 1.0目的,本篇文档探讨索引rebuild 与 rebuild online的区别 2.0猜测:已有的知识 2.1对索引rebuild重建会对表申 ...

  9. 小米 OJ 编程比赛 03 月常规赛

    A.数学等式 数据比较小,可以暴力+折半枚举. #include<bits/stdc++.h> #define ll long long #define rep(i,a,b) for(in ...

  10. next_permutation函数和per_permiutation函数

    next_permutation用于求有序数组里面的下一个排序,形式为next_permutation(数组名,数组名+n)