当前位置: 首页 > article >正文

Java中ArrayList remove会遇到的坑

前言

平时最常用的莫过于ArrayList和HashMap了,面试的时候也是问答的常客。先不去管容量、负载因子什么的,就是简单的使用也会遇到坑。

Remove 元素

经常遇到的一个场景是:遍历list, 然后找到合适条件的给删除掉,比如删除所有的偶数。

@Test
public void testRemove2(){List<Integer> integers = new ArrayList<>(5);integers.add(1);integers.add(2);integers.add(2);integers.add(4);integers.add(5);for (int i = 0; i < integers.size(); i++) {if (integers.get(i)%2==0){integers.remove(i);}}System.out.println(integers);
}

看起来好像没问题,加入面试的时候当面问:输出结果是什么?再问真不会报错吗?再问结果是什么?

  • 报错
  • 结果是空list
  • 结果是[1, 2, 5]

注意:每次integers.remove(i)之后,integer.size()都会被重新算一遍

List.remove()有两个,一个 public E remove(int index),一个是public boolean remove(Object o) ,那下面的结果是什么:

@Test
public void testRemove(){ArrayList<Integer> integers = Lists.newArrayList(1, 2, 3, 4);System.out.println(integers);integers.remove(1);System.out.println(integers);
}
  • [1, 3, 4]

注意:
1: 如果里面的类型是Integer时正常调用remove()方法使用的是remove(int index),只有用到forEach,调用remove()方法使用的才是remove(object o);
2: 如果类型不是Integer,如是String类型,则remove(X x)X输入的是String类型则调用remove(Object o),如果输的是数字则调用的是remove(int index)

经常会使用一个Arrays.asList的API, 那么下面的结果是什么

@Test
public void testRemove3(){List<String> list = Arrays.asList("a","b");list.add("c");System.out.println(list);
}
  • 报错: java.lang.UnsupportedOperationException

使用foreach是否可以实现刚开始的问题

@Test
public void testRemove4(){List<String> strings = new ArrayList<>();strings.add("a");strings.add("b");strings.add("c");strings.add("d");for (String string : strings) {strings.remove(string);}
}
  • 否,报错java.util.ConcurrentModificationException

为了性能问题,我们推荐把list.size的计算提取出来

@Test
public void testRemove5(){List<String> strings = new ArrayList<>();strings.add("a");strings.add("b");strings.add("c");strings.add("d");int size = strings.size();for (int i = 0; i < size; i++) {strings.remove(i);}}
  • 报错: java.lang.IndexOutOfBoundsException: Index: 2, Size: 2
  • 这是很好的习惯, 不像开头那样每次循环都计算一次size,而且按这种情况还可以再运行的时候报错。文初的做法不报错,但结果并不是我们想要的。

注意: 如果是用了迭代器,且不可用原来对象进行remove(X x),要使用迭代器对象的remove(X x),原因请看: https://editor.csdn.net/md/?articleId=118524706

使用Iterator是不是就可以remove了

@Test
public void testRemove6(){List<String> strings = new ArrayList<>();strings.add("a");strings.add("b");strings.add("c");strings.add("d");Iterator<String> iterator = strings.iterator();while (iterator.hasNext()){String next = iterator.next();strings.remove(next);}System.out.println(strings);
}
  • 报错: java.util.ConcurrentModificationException

正确的remove做法是什么

@Test
public void testRemove7(){List<String> strings = new ArrayList<>();strings.add("a");strings.add("b");strings.add("c");strings.add("d");Iterator<String> iterator = strings.iterator();while (iterator.hasNext()){String next = iterator.next();iterator.remove();}System.out.println(strings);
}
http://www.lryc.cn/news/2420698.html

相关文章:

  • java小程序_Java小程序
  • 解决Apache出现的CPU高占用率的问题
  • 做自媒体,怎么做赚钱?这3点很关键
  • java集成京东联盟且订单绑定自有平台用户代码实现(保证可用)
  • win10卸载CUDA10.0重新安装10.2以及torch1.6-gpu和tf2.2-gpu环境的配置
  • 视达配色教程13 黄色的色彩性格是什么
  • 学习linux的一些网络资源
  • 单射、双射、满射
  • 软件测试人员必备的60个测试工具,果断收藏了!
  • CPU分析系列--sysstat(mpstat+pidstat)分析系统CPU和I/O负载
  • 微软杀毒软件Microsoft Security Essentials试用
  • 什么是ISTQB认证
  • NandFlash驱动源码详细分析
  • javaWeb酒店客房管理系统
  • CAYEE——INS803
  • Keras中Dropout的用法详解
  • php免费开源多用户商城,开源php多用户商城系统好不好?
  • VF6.0常用命令和主要程序命令
  • 真的假的?94年出生985高校博士生导师道翰天琼认知智能机器人平台API接口大脑为您揭秘。
  • Exchange 2003安装详细教程(三)
  • VMware vSphere 5.1 各种ISO文件大集合[文件数:135][47.6 GB][含激活KEY]
  • HTML5 游戏高级教程(五)
  • 基于Hadoop架构下的FineBI大数据引擎技术原理
  • 四川2021年高考成绩等位分查询,2019年四川高考等位分查询,志愿填报更精准!...
  • 宇宙最强帕鲁私服管理器诞生了!
  • 网站跳出率(Bounce Rate)
  • 林格斯添加真人语音库
  • “零信任网络”(Zero Trust Network)安全是网络安全最高级吗?
  • 称呼大全,亲戚称呼,祖宗十八代的称呼!
  • 贫瘠之地手游一直显示连接服务器,《炉石传说》贫瘠之地的锤炼进入异常解决攻略 进不去如何解决...