黑马程序员_日记35_JavaListIterator
来源:互联网 发布:javascript 数组clear 编辑:程序博客网 时间:2024/05/21 18:44
——- android培训、java培训、期待与您交流! ———-
查阅API得到ListIterator的基本介绍:
public interface ListIteratorextends Iterator系列表迭代器,
允许程序员按任一方向遍历列表、迭代期间修改列表,
并获得迭代器在列表中的当前位置。
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]
要想变成这样,可以利用正向遍历语句。
下面是运行结果图:
ListIterator正向遍历结果
ListIterator正向遍历后再逆向遍历后的结果
ListIterator添加元素后
ListIterator修改元素后的集合
- 黑马程序员_日记35_JavaListIterator
- 黑马程序员_学习日记3_WinForm
- 黑马程序员_学习日记8_HTML
- 黑马程序员_学习日记16_JavaScript
- 黑马程序员_学习日记19_jQuery
- 黑马程序员_学习日记十一_GUI
- 黑马程序员_java学习日记_数组
- 黑马程序员_java学习日记_集合
- 黑马程序员_学习日记57_702HTML
- 黑马程序员_学习日记58_703JavaScript
- 黑马程序员_日记01(多线程)
- 黑马程序员_日记02(IO)
- 黑马程序员_日记03(网络编程)
- 黑马程序员_学习日记 static
- 黑马程序员_学习日记 struct class
- 黑马程序员_日记1--Java函数
- 黑马程序员_日记2--Java数组
- 黑马程序员_日记5_Java多态
- 关于Xilinx芯片中Block RAM和Distributed RAM 的区别
- Eclipse背景设置
- C++实现自己的插件框架 基于QtCreator源码裁剪
- Dojo错误解析之:SyntaxError: missing ] after element list
- 招聘会求贤也蛮拼的 老总的大奔开出来接面试者
- 黑马程序员_日记35_JavaListIterator
- 软件测试需要读的书
- 服务端管理工具编写(二)——公共函数及配置文件读写
- Face Alignment at 3000 FPS via Regressing Local Binary Features 论文学习
- LinearLayout API 分析
- [C++杂记] map/set iterator not dereferencable异常
- Subsets -- leetcode
- template放置位置错误导致backbone报错
- win10不能连接vpn解决方法