java.util.ListIterator
列表迭代器并不持有當前元素的引用,其持有的游標是位于列表連個元素之間。可以通過調用next()或者previous()返回列表中的元素。一個擁有n個元素的列表擁有n+1個游標位置,示意圖如下:
注意:remove和?set(Object)方法并不是以迭代器的游標為準,而是以最后一次調用迭代器的next()或者previous()方法的返回的元素為準。
基礎方法
1.boolean hasNext();
當在迭代器正向遍歷仍有可訪問的有效元素時,則返回true,換句話說,如果調用next()方法可以返回一個有效元素時,則會返回true,否則返回false。
2.E next();返回迭代器正向訪問時的下一個元素,并將迭代器游標進行自增操作。我們可以通過循環調用這個方法達到遍歷列表中的目的。同時,我們也可以調用previous()方法來逆向遍歷列表。當我們交替調用next()與previous()時,迭代器將返回相同的元素。
3.boolean hasPrevious();當迭代器逆向遍歷仍有可以訪問的有效元素時,則返回true。也就是說,當調用方法previous()仍然可以返回一個有效元素時,則返回true。
4.E previous();返回逆向遍歷列表的下一個元素,并將迭代器的游標進行自減操作。
5.int nextIndex();返回下一次調用next()時返回的元素的下標。當列表迭代器到達列表末尾時,則會回列表長度。
6.int previousIndex();返回下一次掉調用previous()時返回的元素的下標。當列表迭代器到達列表頭部時,則返回-1。
7.void remove();刪除最后一次調用next()或者previous()返回的元素。調用該方法有兩個注意點:
替換最后一次調用next()或者previous()返回的元素。在調用本方法前,不可調用add(E)和remove()方法。
9.void add(E e);在列表中插入一個新元素。如果next()可以訪問有效元素,則將元素插入到調用next()方法返回的元素之前。即:如果previous()可以訪問有效元素,則將元素插入到調用previous()方法返回的元素之后。當列表為空時,則插入的元素為列表中唯一的元素。新元素的插入位置為當前迭代器指定的游標之前,即:插入元素后,調用next()返回元素不受影響,而調用previous()函數,則會返回剛剛插入的新元素。調用這個方法后,會使調用nextIndex()或previousIndex()的結構都增大1。插入元素前后的示意圖如下:
轉載于:https://www.cnblogs.com/czcys/p/6214422.html
總結
以上是生活随笔為你收集整理的java.util.ListIterator的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: python web前端开发框架,pyt
- 下一篇: HFSS 天线设计流程概述-截图