c语言sscanf函数的用法是什么
343
2023-02-16
浅谈Java list.remove( )方法需要注意的两个坑
list.remove
最近做项目的过程中,需要用到list.remove()方法,结果发现两个有趣的坑,经过分析后找到原因,记录一下跟大家分享一下。
代码
直接上一段代码,进行分析。
public class Main {
public static void main(String[] args) {
List
List
stringList.add("a");
stringList.add("b");
stringList.add("c");
stringList.add("d");
stringList.add("e");
integerList.add(2);
integerList.add(4);//此处相当于要移除最后一个数据
for (Integer i :integerList){
stringList.remove(i);
}
for (String s :stringList){
System.out.println(s);
}
}
}
如上代码我们有一个5个元素的list数据集合,我们要删除第2个和第4个位置的数据。
第一次运行
咦,为什么执行两次remove(),stringList的数据没有变化呢?
没有报错,说明代码没有问题,那问题出在哪呢?
仔细分析我们发现,remove()这个方法是一个重载方法,即remove(int position)和remove(object object),唯一的区别是参数类型。
for (Integer i :integerList){
stringList.remove(i);
}
仔细观察上面代码你会发现,其实i是Integer对象,而由于java系统中如果找不到准确的对象,会自动向上升级,而(int < Integer < Object),所以在调用stringList.remove(i)时,其实使用的remove(object object),而很明显stringList不存在Integer对象,自然会移除失败(0.0),Java也不会因此报错。
如果我们想使用remove(int position)方法,只能降低对象等级,即修改代码;
for (Integer i :integerList){
int a =i;
stringList.remove(a);
}
第二次运行
我们发现提示在坐标为4的地方越界了,这是为什么呢?
其实很简单,因为执行stringList.remove(2)后,list.size()就-1为4了,我们原来要移除的最后一个位置的数据移动到了第3个位置上,自然就造成了越界。
我们修改代码先执行stringList.remove(4),再执行执行stringList.remove(2)。
integerList.add(4);
integerList.add(2);
这个错误提醒我们:使用remove()的方法时,要先从大到小的位置移除。当然如果你知道具体的对象,直接移除remove(对象)更稳妥。
第三次执行
嗯,这次没问题了。
总结
1、使用remove()的方法时,要先从大到小的位置移除。当然如果你知道具体的对象,直接移除remove(对象)更稳妥。
2、要密切注意自己调用的remove()方法中的,传入的是int类http://型还是一个对象。
补充知识: 关于List.remove()报错的问题
我们如果想删掉List中某一个对象,我们可能就会想到会用List.remove()方法。但是这样如果后续操作这个list的时候就会报错。
具体的原因是当你操作了List的remove方法的时候,他回去修改List的modCount属性。
导致抛出异常java.util.ConcurrentModificationException。
最好的想要修改List对象,我们可以用ListIterator。
就像这样:
ArrayList
for (int i = 0; i < 20; i++) {
arrayList.add(Integer.valueOf(i));
}
ListIterator
while (iterator.hasNext()) {
if(需要满足的条件hlkDLqz){
iterator.remove();//删除操作
iterator.add(integer);//新增操作
}
}
这样就不会去修改List的modCount属性。
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~