迭代器
一、迭代器的实现原理
Iterator接口的两个抽象方法:hasNext()和next()。首先,集合的指针位于索引-1的位置,每当调用一次next()后,指针向右移一位。然后有hasNext()来判断当前指针的位置处是否有元素。
**注:**迭代器只能使用一次,因为在一次迭代完之后,指针已经跑到最后一位,这是再调用next()来移动指针就无效了。(在进行集合元素取出时,如果集合中已经没有元素可以取了,即指针已指向最后一位,此时,如果继续使用迭代器的next()方法,将会发生没有集合元素的异常)。
二、迭代器接口中的抽象方法
- 如果仍有元素可以迭代,则返回true(判断集合中还有没有可以被取出的元素)
boolean hasNext()
- 返回迭代的下一个元素,并把指针向后移动一位(取出集合中的下一个元素)
E next()
三、迭代器的代码演示
- 在Collection接口描述了一个抽象方法iterator方法,所有Collection子类都实现了这个方法,并且有自己的迭代形式。
import java.util.ArrayList;
import java.util.Collection;
import java.util.Iterator;
public class Demo {
public static void main(String[] args) {
Collection<String> coll = new ArrayList<String>();
coll.add("abc1");
coll.add("abc2");
coll.add("abc3");
coll.add("abc4");
Iterator<String> it = coll.iterator();
//下面的while循环实现了迭代器的功能
while(it.hasNext()){
String s = it.next();
System.out.println(s);
}
}
}
- 运行结果
增强for循环
一、增强for循环的特点
- 是Iterable接口的实现类
- 优点:简化代码,代码量小
- 缺点:没有索引,不能操作容器里面的元素
二、增强for循环的格式
for( 数据类型 变量名 : 数组或者集合 ){
方法(变量名);
}