| 
 
| 查阅API得到ListIterator的基本介绍: 
 public interface ListIterator<E>extends Iterator<E>系列表迭代器,允许程序员按任一方向遍历列表、迭代期间修改列表,
 并获得迭代器在列表中的当前位置。
 ListIterator没有当前元素;
 它的光标位置始终位于调用 previous() 所返回的元素和调用 next() 所返回的元素之间。
 
 方法
 void add(E e)
 将指定的元素插入列表(可选操作)。
 boolean hasNext()
 以正向遍历列表时,如果列表迭代器有多个元素,则返回 true(换句话说,如果 next 返回一个元素而不是抛出异常,则返回 true)。
 boolean hasPrevious()
 如果以逆向遍历列表,列表迭代器有多个元素,则返回 true。
 E next()
 返回列表中的下一个元素。
 int nextIndex()
 返回对 next 的后续调用所返回元素的索引。
 E previous()
 返回列表中的前一个元素。
 int previousIndex()
 返回对 previous 的后续调用所返回元素的索引。
 void remove()
 从列表中移除由 next 或 previous 返回的最后一个元素(可选操作)。
 void set(E e)
 用指定元素替换 next 或 previous 返回的最后一个元素(可选操作)。
 
 下面谈谈我对ListIterator的理解。
 ListIterator是List集合特有的迭代器,中文名字叫做列表迭代器。
 那么为什么List会有这么独特的一个迭代器呢?
 在使用迭代器迭代的时候,是不可以使用集合的操作方法的,
 因为会发生ConcurrentModificationException,即并发修改异常。
 
 所以在使用迭代器时,只能使用迭代器有的方法,
 可是Iterator只有三种方法,
 使用Iterator只能进行判断,取出和删除操作。
 如果想要添加,修改等操作,就必须使用ListIterator接口了。
 
 需要注意的是:ListIterator接口只能通过List集合获取。
 可以通过ListIterator listLiterator()方法获取接口的迭代器。
 
 下面对ListIterator方法进行演示。
 
 复制代码import java.util.*;
class ListIteratorDemo 
{
        public static void main(String[] args) 
        {
                method_ListIterator();
        }
        //演示ListIterator
        public static void method_ListIterator()
        {
                //创建一个集合
                ArrayList al = new ArrayList();
                //共性方法给集合添加元素
                al.add("num01");
                al.add("num02");
                al.add("num03");
                //打印原有集合
                System.out.println("原有集合"+al);
                
                //创建ListIterator迭代器,
                ListIterator li = al.listIterator();
                
                
                //并对集合集合进行正向遍历
                while(li.hasNext())
                        System.out.println(li.next());
                
                //并对集合集合进行逆向遍历
                while(li.hasPrevious())
                        System.out.println(li.previous());
                //ListIterator特有的添加方法
                li.add("num04");
                //li.add("num05");//添加元素后的集合:[num04, num05, num01, num02, num03]
                //打印集合
                System.out.println("添加元素后的集合:"+al);
                //修改
                while(li.hasNext())
                {
                        //设置一个临时引用指向集合元素
                        Object obj = li.next();
                        //修改指定元素
                        if(obj.equals("num02"))
                                li.set("num10");
                }
                //打印被修改过后的集合
                System.out.println("修改元素“num02”为“num10”后的集合:"+al);
        }
}
说明一下ListIterator正向遍历和逆向遍历的原理,以及添加的原理。
 原理就是操作指针。
 原有集合[头][num01, num02, num03]
 初始     ↑
 hasNext = true;
 hasPrevious = false;
 正向遍历后[头][num01, num02, num03]
 指针位置                     ↑
 hasNext = false;
 hasPrevious = true;
 
 所以在上面的例子中执行添加操作结果是
 添加元素后的集合:[num04, num01, num02, num03]
 而不是[ num01, num02, num03,num04]
 要想变成这样,可以利用正向遍历语句。
 
 
 
 | 
 
  组图打开中,请稍候...... |