谁能解释下这个结果
import java.io.*;
import java.util.*;
public class ItDemo {
/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
List list=new ArrayList();
list.add(new InClass(1));
list.add(new InClass(2));
ListIterator iterator=list.listIterator();
System.out.println( "a[ "+iterator.nextIndex()+ "]= "+((InClass)iterator.next()).get());
System.out.println( "当前位置的下一个位置 "+iterator.nextIndex());
System.out.println( "当前位置的上一个位置 "+iterator.previousIndex());
System.out.println( "a[ "+iterator.previousIndex()+ "]= "+((InClass)iterator.previous()).get());
}
}
输出:
a[0]=1
当前位置的下一个位置1
当前位置的上一个位置0
a[0]=1
===================================
当前位置的下一个位置1
当前位置的上一个位置0
那当前位置是个什么东西啊
这个iterator到底这么弄啊
------解决方案--------------------iterator是一个迭代器,它是集合类的一个方法,可以通过它来得到这个集合的所有元素,你可以查JDK文档,上面写得很清楚,就好像数组的下标一样,数组要通过下标才能方便得访问他的元素,其实你可以把它看作一个指针,这样就比较好理解了。。。
------解决方案--------------------理解Iterator 不要理解为指针,否则很头疼.
如果你手中有CoreJava下册在手中,你可以看它第二章讲解的集合.对于Iterator有比较容易理解的图示.
---对象1---对象2---对象3--等
!
iterator
iterator初始位置(位于第一个对象之前)
iterator.next(),返回第一个对象(当然之前要用hasNext()判断),此时的位置为:
---对象1---对象2---对象3--等
!
iterator
对于iterator.previous可以同样理解.
------解决方案--------------------系列表迭代器,允许程序员按任一方向遍历列表、迭代期间修改列表,并获得迭代器在列表中的当前位置。ListIterator 没有当前元素;它的光标位置 始终位于调用 previous() 所返回的元素和调用 next() 所返回的元素之间。在长度为 n 的列表中,有 n+1 个有效的索引值,从 0 到 n(包含)。
Element(0) Element(1) Element(2) ... Element(n)
^ ^ ^ ^ ^
Index: 0 1 2 3 n+1
^就是当前位置