迭代器(Iterator)
-
next()方法可以获得下一个元素,第一次调用next()方法的时候返回的是第一个元素
-
hasNext()方法可以用来检查是否还有元素
-
remove()方法删除迭代器返回的最近一个元素
package src.com.sw.t2; import java.util.ArrayList; import java.util.Iterator; public class ITest { public static void main(String[] args) { ArrayList<Integer> arr = new ArrayList<Integer>(); for(int i=0;i<9;i++){ arr.add(i); } Iterator it = arr.iterator(); //迭代器用于while循环 while(it.hasNext()) {//判断是否还有元素,如果没有了就终止循环 System.out.print(it.next());//输出下一个元素,第一次调用的时候 //则返回的是第一个元素 //输出012345678 } //it.next();//没有使用这个方法直接使用remove()方法会报错 it.remove(); } }
因为remove()方法是要移除迭代器最近返回的元素,所以在没有是使用next()方法之前使用remove()方法的话是会报错的
-
ListIterator迭代器是继承自Iterator专门针对List的,它可以从两个方向来遍历List,并且还支持元素的修改
相比于Iterator,ListIterator多了几个方法
- hasPrevious()方法,从后往前遍历的时候看前面是后还是元素
- previous()方法,返回上一个元素
- nextIndex()方法,返回下一个将由next()方法返回的元素的下标
- previousIndex()方法,返回下一个将由previous()方法返回的元素的下标
- set(E e)方法,把next或者previous返回的最后一个元素用指定的元素代替,并且只有在调用next或者previous后没有调用remove和add方法才可以调用,不然也会报错。
- add(E e)方法,把指定元素插入到next返回的元素的前面或者previous返回的元素的后面,如果没有的话,这个新元素就是列表唯一的元素,它是把新的元素加到迭代器当前位置的左边。
package src.com.sw.t2; import java.util.ArrayList; import java.util.ListIterator; public class ITest { public static void main(String[] args) { ArrayList<Integer> arr = new ArrayList<Integer>(); arr.add(1); arr.add(2); ListIterator it = arr.listIterator(); /* it.add(3);//使用迭代器的add方法加一个元素 while (it.hasPrevious()) {//这里从右往左遍历才能访问到新增加的元素 System.out.print(it.previous());//输出3 }*/ } }
package src.com.sw.t2; import java.util.ArrayList; import java.util.ListIterator; public class ITest { public static void print(ListIterator it) { while (it.hasNext()) { System.out.print(it.next()); } } public static void main(String[] args) { ArrayList<Integer> arr = new ArrayList<Integer>(); for (int i=0;i<6;i++) arr.add(i); ListIterator it = arr.listIterator();//此时的迭代器在元素0的前面 it.next();//返回0 System.out.println(it.nextIndex());//输出1,是it迭代器下一次调用next方 //法将要返回的值。表示此时迭代器以及在元素0和1之间了 it.set(9);//把0换成9 ListIterator it1 = arr.listIterator();//让迭代器重头开始 print(it1);//输出912345, } }