迭代指的是重复的过程,这个接口就是来定义被重复执行的一个过程的标准。为啥需要这个东西呢?Collection的两个子类List和Set,在迭代List和Set时,使用的方式不同,List用有迭代因子来进行迭代,Set用for-each迭代,两个容器的迭代方式不同,为了统一,使用Iterator迭代器,对List和Set统一进行迭代。
单例集合实现了Iterator接口,在该接口中包含一个名为iterator的抽象方法,所有实现了Collection接口的容器类对该方法做了具体实现。iterator方法会返回一个Iterator接口类型的迭代器对象。
在Iterator对象中使用移动游标的方式实现迭代处理
Iterator接口定义了如下方法:
-
boolean hasNext(); //判断游标当前位置是否有元素,如果有返回true,否则返回false;
-
Object next(); //获取当前游标所在位置的元素,在执行完next后操作只能执行一次;
-
void remove(); //删除游标当前位置的元素,在执行完next后该操作只能执行一次;
1.迭代List接口容器
import java.util.List;
import java.util.*;
public class IteratorListTest {
public static void main(String[] args) {
//实例化
List<String> list = new ArrayList<>();
list.add("a");
list.add("b");
list.add("c");
//获取元素
//获取迭代器对象,迭代器决定如何获取元素,没有循环能力
Iterator<String> iterator =list.iterator();
//方式一,在迭代器中通过while循环获取元素
while(iterator.hasNext()) {
String value = iterator.next();
System.out.println(value);
}
System.out.println("---------------");
//方式二,在迭代器中,通过for循环获取元素
for(Iterator<String> it = list.iterator();it.hasNext();) {
String value = it.next();
System.out.println(value);
}
}
}
2.迭代Set容器接口
import java.util.*; //以前是要用for-each来实现的
public class IteratorSetTest {
public static void main(String[] args) {
//实例化Set类型的容器
Set<String> set = new HashSet<>();
set.add("a");
set.add("b");
set.add("c");
//获取迭代器对象
Iterator<String> iterator = set.iterator();
//方式一,通过while循环
while(iterator.hasNext()) {
String value = iterator.next();
System.out.println(value);
}
System.out.println("----------");
//方式二,for循环
for(Iterator<String> it = set.iterator();it.hasNext();) {
String value = it.next();
System.out.println(value);
}
}
}
3.在迭代器中删除元素
//这里随便写写吧
import java.util.*;
public class IteratorRemoveTest {
public static void main(String[] args) {
List<String> list = new ArrayList<>();
list.add("a");
list.add("b");
list.add("c");
list.add("d");
int flag = -1;
for(int i=0;i<list.size();i++) { //list.size()也会发生变化
//list.remove(2); //注意,删除的时候元素会移动,所以不要在循环里面删除指定元素
//所以要做的话用if判断
//if("c".equals(list.get(i))) {
// list.remove(i);
//}
if("c".equals(list.get(i))) {
flag =i ;
}
System.out.println(list.get(i));
}
if(flag>-1) { //在外部删除指定元素
list.remove(flag);
}
}
}