在进行List集合的删除操作时,新手入手时绝大多数肯定会是for循环遍历List集合。【其中id是一个参数,al是一个List集合的名字】
for(int i=0;i<al.size();i++) {
Map<String, Object> map = al.get(i);
System.out.println("al:"+al.get(i));
Iterator<String> iterator = map.keySet().iterator();
while(iterator.hasNext()) {
String key = iterator.next();
Card card = (Card) map.get(key);
if(card.getId()==Integer.parseInt(id)) {
System.out.println(map);
al.remove(i);
break;
}
}
}
这样在操作数据的时候,会产生数据的“丢失”——即跳过要操作的数据的下一个数据。
下面有两种方式解决这样的问题:
方法一:运用倒叙的方式进行遍历此List集合。【因为List集合在进行删除操作时,删除某个元素后,集合中后面的数据会自动往上顶,则下一条数据就会自动覆盖在已删除数据的空间,依次覆盖;所以就会导致此数据(下一条数据)不进行数据循环。致使我们看到的数据“丢失”。】
//第一种方法1.for(int i=al.size()-1; ;i--) {//倒叙的遍历
for(int i=al.size()-1;i>=0;i--) {
Map<String, Object> map = al.get(i);
System.out.println("al:"+al.get(i));
Iterator<String> iterator = map.keySet().iterator();
while(iterator.hasNext()) {
String key = iterator.next();
Card card = (Card) map.get(key);
if(card.getId()==Integer.parseInt(id)) {
System.out.println(map);
al.remove(i);
break;
}
}
}
方法二:运用List集合自身的迭代器“Iterator”进行遍历。
//第二种方法2.List集合自身的迭代器进行数据的删除
Iterator<Map<String, Object>> it = al.iterator();
while(it.hasNext()) {
Map<String, Object> map = it.next();
System.out.println("al:"+map);
Iterator<String> iterator = map.keySet().iterator();
while(iterator.hasNext()) {
String key = iterator.next();
Card card = (Card) map.get(key);
System.out.println("未进"+map);
for(int j=0;j<ids.length;j++) {
System.out.println(card.getId()==Integer.parseInt(ids[j]));
System.out.println("正准备进"+map);
if(card.getId()==Integer.parseInt(ids[j])) {
System.out.println("进入"+map);
//使用迭代器进行删除
it.remove();
}
}
}
}
学习过程中的总结,希望能帮到大家。
本文探讨了在Java中处理List集合删除操作时常见的问题及解决方案,包括数据“丢失”现象的成因,以及如何通过倒叙遍历和使用Iterator迭代器避免这一问题。
237

被折叠的 条评论
为什么被折叠?



