java聚集迭代器Iterator中的remove圈套。本站提示廣大學習愛好者:(java聚集迭代器Iterator中的remove圈套)文章只能為提供參考,不一定能成為您想要的結果。以下是java聚集迭代器Iterator中的remove圈套正文
package TestList;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import java.util.TreeSet;
public class TestIterator {
/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
List<String> list = new ArrayList<String>();
list.add("aaa");
list.add("bbb");
list.add("ccc");
Iterator t = list.iterator();
while(t.hasNext()){
if(t.next().equals("bbb")){ //應用iterator遍歷list聚集時,假如想要刪除任一聚集內元素,必需要在正好遍歷倒數第二個元素的時刻去刪除
list.remove("ccc");
}
}
TreeSet<String> set = new TreeSet<String>();
set.add("ddd");
set.add("eee");
set.add("fff");
Iterator t1 = set.iterator();
while(t1.hasNext()){
if(t1.next().equals("fff")){ //應用iterator遍歷set聚集時,假如想要刪除任一聚集內元素,必需要在正好遍歷倒數第一個元素的時刻去刪除
set.remove("eee");
}
}
}
}
因為List,Set在完成Iterator時存在必定的差別,是以招致了List,Set在迭代的同時刪除聚集元素的會有分歧的表示