java重置迭代器指针位置_Iterator、Iterable接口的使用及详解

Java集合类库将集合的接口与实现分离。同样的接口,可以有不同的实现。

Java集合类的基本接口是Collection接口。而Collection接口必须实现Iterator接口。

以下图表示集合框架的接口,java.lang以及java.util两个包里的。其他部分可以从左向右看,比如Collection的Subinterfaces有List,Set以及Queue等。

e7ff6c1ea128107737898272ed07aac6.png

48304ba5e6f9fe08f3fa1abda7d326ab.png

package java.util;

/**

* An iterator over a collection. Iterator takes the place of Enumeration in

* the Java collections framework. Iterators differ from enumerations in two

* ways:

*

Iterators allow the caller to remove elements from the

* underlying collection during the iteration with well-defined

* semantics.

*

Method names have been improved.

*

*

* This interface is a member of the

*

* Java Collections Framework.

*

* @author Josh Bloch

* @version %I%, %G%

* @see Collection

* @see ListIterator

* @see Enumeration

* @since 1.2

*/

public interface Iterator {

/**

* Returns true if the iteration has more elements. (In other

* words, returns true if next would return an element

* rather than throwing an exception.)

*

* @return true if the iterator has more elements.

*/

boolean hasNext();

/**

* Returns the next element (每一次迭代,the next element就是index为0的元素)in the iteration.

*

* @return the next element in the iteration.

* @exception NoSuchElementException iteration has no more elements.

*/

E next();

/**

*

* Removes from the underlying collection the last element returned by the

* iterator (optional operation). This method can be called only once per

* call to next. The behavior of an iterator is unspecified if

* the underlying collection is modified while the iteration is in

* progress in any way other than by calling this method.

*

* @exception UnsupportedOperationException if the remove

* operation is not supported by this Iterator.

* @exception IllegalStateException if the next method has not

* yet been called, or the remove method has already

* been called after the last call to the next

* method.

*/

void remove();

}

48304ba5e6f9fe08f3fa1abda7d326ab.png

以下例子是利用了Iterator接口的着三个方法,实现遍历ArrayList类型。

一开始迭代器在所有元素的左边,调用next()之后,迭代器移到第一个和第二个元素之间,next()方法返回迭代器刚刚经过的元素。

hasNext()若返回True,则表明接下来还有元素,迭代器不在尾部。

remove()方法必须和next方法一起使用,功能是去除刚刚next方法返回的元素。

48304ba5e6f9fe08f3fa1abda7d326ab.png

import java.util.ArrayList;

import java.util.Collection;

import java.util.Iterator;

public class ForEachDemo {

public static void main(String... arg) {

Collection a = new ArrayList();

a.add("Bob");

a.add("Alice");

a.add("Lisy");

Iterator iterator = a.iterator();

while (iterator.hasNext()) {

String ele = iterator.next();

System.out.println(ele);//Bob Alice Lisy

}

System.out.println(a);//[Bob, Alice, Lisy]

iterator = a.iterator();

iterator.next();

iterator.remove();

System.out.println(a);//[Alice, Lisy]

}

}

48304ba5e6f9fe08f3fa1abda7d326ab.png

48304ba5e6f9fe08f3fa1abda7d326ab.png

package java.lang;

import java.util.Iterator;

/** Implementing this interface allows an object to be the target of

* the "foreach" statement.

* @since 1.5

*/

public interface Iterable {

/**

* Returns an iterator over a set of elements of type T.

*

* @return an Iterator.

*/

Iterator iterator();

}

48304ba5e6f9fe08f3fa1abda7d326ab.png

for-each循环可以与任何实现了Iterable接口的对象一起工作。

而Collection接口扩展了Iterable接口,故标准类库中的任何集合都可以使用for-each循环。

Collection接口

此接口的方法

public interface Collection{......}

Modifier and TypeMethod and Description

boolean

Ensures that this collection contains the specified element (optional operation).

boolean

Adds all of the elements in the specified collection to this collection (optional operation).

void

Removes all of the elements from this collection (optional operation).

boolean

Returns true if this collection contains the specified element.

boolean

Returns true if this collection contains all of the elements in the specified collection.

boolean

Compares the specified object with this collection for equality.

int

Returns the hash code value for this collection.

boolean

Returns true if this collection contains no elements.

Returns an iterator over the elements in this collection.

boolean

Removes a single instance of the specified element from this collection, if it is present (optional operation).

boolean

Removes all of this collection's elements that are also contained in the specified collection (optional operation).

boolean

Retains only the elements in this collection that are contained in the specified collection (optional operation).

int

Returns the number of elements in this collection.

Returns an array containing all of the elements in this collection.

 T[]

Returns an array containing all of the elements in this collection; the runtime type of the returned array is that of the specified array.

因为其中有一个返回值为Iterator类型的iterator()方法,所以,Collection接口必须实现Iterator接口

实现Collection接口的每一个类都要实现以上众多方法,但开发者自己实现很麻烦。所以java提供了AbstractCollection类来编写具体的类。

java.util

Interface Collection

All Superinterfaces:

Collection接口有三个常用的子接口,分别是List,Set,Queue。

http://blog.csdn.net/xujinsmile/article/details/8543544

为什么一定要去实现Iterable这个接口呢? 为什么不直接实现Iterator接口呢?

看一下JDK中的集合类,比如List一族或者Set一族,

都是实现了Iterable接口,但并不直接实现Iterator接口。

仔细想一下这么做是有道理的。因为Iterator接口的核心方法next()或者hasNext()

是依赖于迭代器的当前迭代位置的。

如果Collection直接实现Iterator接口,势必导致集合对象中包含当前迭代位置的数据(指针)。

当集合在不同方法间被传递时,由于当前迭代位置不可预置,那么next()方法的结果会变成不可预知。

除非再为Iterator接口添加一个reset()方法,用来重置当前迭代位置。

但即时这样,Collection也只能同时存在一个当前迭代位置。

而Iterable则不然,每次调用都会返回一个从头开始计数的迭代器。

多个迭代器是互不干扰的。

http://www.cnblogs.com/highriver/archive/2011/07/27/2077913.html

48304ba5e6f9fe08f3fa1abda7d326ab.png

import java.util.Iterator;

public class ForEachAPIDemo {

public static void main(String[] args) throws Exception {

Students students = new Students(10);

for (Student student : students) {

System.out.println(student.getSid() + ":" + student.getName());

}

}

}

// 支持for each迭代循环的学生集合类

class Students implements Iterable {

// 存储所有学生类的数组

private Student[] students;

// 该构造函数可以生成指定大小的学生类变量数组,并初始化该学生类变量数组

public Students(int size) {

students = new Student[size];

for (int i = 0; i < size; i++) {

students[i] = new Student(String.valueOf(i), "学生" + String.valueOf(i));

}

}

@Override

public Iterator iterator() {

return new StudentIterator();

}

// 实现Iterator接口的私有内部类,外界无法直接访问

private class StudentIterator implements Iterator {

// 当前迭代元素的下标

private int index = 0;

// 判断是否还有下一个元素,如果迭代到最后一个元素就返回false

public boolean hasNext() {

return index != students.length;

}

@Override

public Student next() {

return students[index++];

}

// 这里不支持,抛出不支持操作异常

public void remove() {

throw new UnsupportedOperationException();

}

}

}

class Student {

private String sid;

private String name;

public Student(String sid, String name) {

setSid(sid);

setName(name);

}

public String getSid() {

return sid;

}

public void setSid(String sid) {

this.sid = sid;

}

public String getName() {

return name;

}

public void setName(String name) {

this.name = name;

}

@Override

public String toString() {

return "Student{" +

"sid='" + sid + '\'' +

", name='" + name + '\'' +

'}';

}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值