迭代指的是重复的过程,这个接口就是来定义被重复执行的一个过程的标准。为啥需要这个东西呢?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后该操作只能执行一次;
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); } } }
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); } } }
//这里随便写写吧 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); } } }