ListIterator,previous的返回值到底是什么

官方文档描述是“Returns the previous element in the list and moves the cursor position backwards.”
即:返回前一个元素,并将迭代器回退。

但是我debug时发现,它返回的似乎是当前元素。
举例:

        LinkedList<Integer> nums = new LinkedList<Integer>();
        for(int i = 0; i < 10; ++i) nums.add(2*i);
        ListIterator<Integer> itr = nums.listIterator();

        for(;itr.hasNext();) itr.next();//遍历1

        for(;itr.hasPrevious();)//遍历2
            System.out.print(itr.previous()+" ");

首先nums存储的值是0,2,4,6,8,10,12,14,16,18

“遍历1”执行完毕之后,itr指向的应该是元素18
那么,假如按官方文档所说,“遍历2”打印的第一个元素应该是16
但是,实际上“遍历2”打印的结果是
18 16 14 12 10 8 6 4 2 0

是官方文档描述有误吗?

通过看源码

        public E next() {
            checkForComodification();
            int i = cursor;
            if (i >= size)
                throw new NoSuchElementException();
            Object[] elementData = ArrayList.this.elementData;
            if (i >= elementData.length)
                throw new ConcurrentModificationException();
            cursor = i + 1;
            return (E) elementData[lastRet = i];
        }

        public E previous() {
            checkForComodification();
            int i = cursor - 1;
            if (i < 0)
                throw new NoSuchElementException();
            Object[] elementData = ArrayList.this.elementData;
            if (i >= elementData.length)
                throw new ConcurrentModificationException();
            cursor = i;
            return (E) elementData[lastRet = i];
        }

nums存储0,2,4,6,8,10,12,14,16,18
nums.listIterator()时,cursor为0
执行itr.next()时,cursor+1,itr.next的返回值为当前cursor未+1前对应的值,比如,开始cursor为0,执行一次itr.next时,返回elementData[0],此时cursor为1
itr.next结束时,cursor为10.
执行itr.previous()时,cursor-1,返回值为当前cursor对应的值。开始执行previous时,cursor为10,执行itr.previous时,cursor-1为9,返回的elementData[9]为18.

按我的理解,返回前一个元素时,是相对于cursor当前指针而言。当前指针位于10,返回的是前一个指针9对应的值。没毛病。。。。