无论使用什么方式对List进行遍历,都不能直接对List<E>变量进行直接修改操作,比如:
输出结果如下:
List<String> strList = new ArrayList<String>();
strList.add("john");strList.add("mark");
strList.add("alen");strList.add("jason");
for(String strElem:strList)
{
if(strElem.equals("john"))
{
strList.add("Davien");
}
}
上面的代码想在“john”后面添加“Davien”,但是很不幸,会抛出java.util.ConcurrentModificationException异常,就是因为对在循环中对strList变量进行直接修改。Iterator可以提供容器类的统一遍历方式,并且可以在遍历中使用remove方法删除元素,但是任然不能解决遍历时修改List的需求,ListIterator在Iterator的基础上添加的pre系列方法,可以实现反向操作,最重要的是添加了add和set方法,可以实现遍历List的时候同时进行添加,修改的操作。请看例子。
package cn.jnk.tools;
import java.util.ArrayList;
import java.util.List;
import java.util.ListIterator;
import org.junit.Test;
/**
* Unit test for simple App.
*/
public class AppTest
{
@Test
public void ListTest()
{
boolean doExceptionTest = false;
List<Phone> phones = new ArrayList<Phone>();
phones.add(new Phone("111"));
phones.add(new Phone("183"));
phones.add(new Phone("182"));
phones.add(new Phone("185"));
System.out.println("原始数据");
for(Phone phoneElem:phones)
{
System.out.println(phoneElem.getNumber());
}
ListIterator<Phone> phoneIterator = phones.listIterator();
while(phoneIterator.hasNext())
{
Phone tmpPhone = phoneIterator.next();
if(tmpPhone.getNumber().equals("111"))
{
tmpPhone.setNumber("666");
phoneIterator.set(tmpPhone);
phoneIterator.add(new Phone("132")); // use ListIterator add item is ok
}
if(tmpPhone.getNumber().equals("183"))
{
phoneIterator.remove();
}
if(doExceptionTest)
{
phones.add(new Phone("170")); // throw java.util.ConcurrentModificationException
}
}
System.out.println("\n修改后正向遍历:");
for(Phone phoneElem:phones)
{
System.out.println(phoneElem.getNumber());
}
System.out.println("\n修改后反向遍历:");
//反向遍历
while(phoneIterator.hasPrevious())
{
System.out.println(phoneIterator.previousIndex() + ": "+phoneIterator.previous().getNumber());
}
}
}
class Phone
{
private String number;
public Phone(){}
public Phone(String number)
{
this.number = number;
}
public String getNumber() {
return number;
}
public void setNumber(String number) {
this.number = number;
}
}
输出结果如下: