Java中Iterable和Iterator的辨析
来源:互联网 发布:java运维是做什么的 编辑:程序博客网 时间:2024/05/16 09:40
转自:http://blog.csdn.net/lipengcn/article/details/51700153
本文主要对Iterable和Iterator两个接口进行深入学习。
1、Iterable接口
Iterable接口 (java.lang.Iterable) 是Java集合的顶级接口之一。我们首先看下这这个接口在JDK中的定义:
package java.lang; public interface Iterable<AnyType>{ Iterator<AnyType> iterator(); }
- 1
(1)可见,Iterable接口中只包含一个方法,就是一个iterator()方法,用来返回一个Iterator类型的对象,或者说返回一个实现了Iterator接口的对象。
(2)实现了Iterable接口的类可以拥有增强的for循环,即只要实现了Iterable接口的类,就可以使用Iterator迭代器了。如
public static <AnyType> void print(Collection<AnyType> coll){ for(AnyType item: coll) System.out.println(item);}
- 1
Tip:注意这里的函数输入参数Collection<AnyType> coll
,其中coll是个接口变量。本来接口是不能用new来实例化一个接口的,即不能构造接口对象,但是可以用来声明接口变量,而且接口变量必须引用实现了接口的类对象。
(3)集合Collection、List、Set都是Iterable的实现类,所以他们及其他们的子类都可以使用foreach进行迭代。
好了,那么下面我们来看下Iterable接口中提到的Iterator接口吧。
2、Iterator接口
首先,我们还是先看下Iterator接口的定义:
package java.util; public interface Iterator<AnyType>{ boolean hasNext(); AnyType next(); void remove(); }
- 1
(1)当编译器见到一个正在用于Iterable对象的增强的for循环的时候,它用对iterator()方法的调用来代替增强的for循环以得到一个Iterator对象,然后调用next和hasNext。我们可以给出iterator()方法的定义
因此,上面Iterable例程可以改写为
public static <AnyType> void print(Collection<AnyType> coll){ Iterator<AnyType> itr = coil.iterator(); while(itr.hasNext()) { AnyType item = itr.next(); System.out.println(item); } }
- 1
(2)Iterator接口中的核心方法next(),hasNext(),remove(),都是依赖当前位置。如果这些集合直接实现Iterator接口,则势必导致集合对象中包含当前迭代位置的数据(指针)。当集合在不同方法间进行传递的时候,由于当前迭代位置不可知,所以next()的结果也不可知。除非再为Iterator接口添加一个reset()方法,用来重置当前迭代位置。 而当实现Iterable则不然,每次调用都返回一个从头开始的迭代器,各个迭代器之间互不影响。
3、综合应用
我们后面会自己实现数据结构ArrayList,其中就用到了Iterable接口和Iterator接口,我们看下这个综合的例子
// Obtains an Iterator object used to traverse the collection public java.util.Iterator<AnyType> iterator() { return new ArrayListIterator(); } /** * This is the implementation of the ArrayListIterator. * It maintains a notion of a current position and * the implicit reference to the MyArrayList. **/ private class ArrayListIterator implements java.util.Iterator<AnyType> { private int current = 0; private boolean okToRemove = false; public boolean hasNest() { return current<size(); } public AnyType next() { if(!hasNext()) throw new java.util.NoSuchElementException(); okToRemove = true; return theItems[current++]; } public void remove() { if(!okToRemove) throw new IllegalStateException(); MyArrayList.this.remove(--current); okToRemove = false; } }
- 1
其中,iterator()方法就直接返回ArrayListIterator类的一个实例,该类是一个实现Iterator接口的类。
- Java中Iterable和Iterator的辨析
- Java中Iterable和Iterator的辨析
- Java中Iterable和Iterator的辨析
- Java中Iterable和Iterator的辨析
- Java中Iterable和Iterator的辨析
- Iterable和Iterator的辨析
- java中Iterator和Iterable的区别
- Java中Iterable和Iterator的区别
- java中Iterator和Iterable的区别
- java 中 Iterator 和 Iterable 区别
- Java中Iterator与Iterable的区别
- Python 中 Iterator和Iterable的区别
- Java中的Iterator和Iterable的区别
- java集合----Iterable和Iterator的区别
- JAVA中ListIterator和Iterator的详解与辨析
- Java中的Iterable和Iterator
- Java迭代器---Iterable和Iterator
- Java Iterable 和 Iterator 示例
- 基于物理的渲染—基于Haar小波基的实时全局光照明
- MYSQL触发器详解
- Python测试代码1之--unittest
- 如何让css背景图片占满全部背景,并且随着浏览器缩放图片保持长宽不变呢?
- sqlserver 临时表
- Java中Iterable和Iterator的辨析
- Android
- 金蝶BOS,服务端执行SQL语句参考
- android_重力传感器(个人笔记)
- Java学习笔记(二十八):java获取路径的问题
- 弹性布局的兼容性
- 序列化类型的对象时检测到循环引用
- 方式程0day MS17-010远程溢出漏洞测试
- day03 java语言基础(运算符与选择结构)