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