一、正序删除
正序删,如果只删除至多1个元素,那只需要在删除后使用break语句跳出循环即可,如果需要删除多个元素,若不注意控制当前列表的size和下一个元素的index,容易报java.lang.indexoutofboundsexception异常
public static void remove(List<String> list, String target) { for(int i = 0, length = list.size(); i < length; i++){ String item = list.get(i); if(target.equals(item)){ list.remove(item); length--; i--; } } }
免费学习视频教程推荐:java教程
二、倒序删除
倒序删可以克服正序删需要额外管理列表size和下一个元素的index的问题,使用起来也很方便
public static void remove(List<String> list, String target) { for(int i = list.size() - 1; i >= 0; i--){ String item = list.get(i); if(target.equals(item)){ list.remove(item); } } }
public static void remove(List<String> list, String target) { Iterator<String> iter = list.iterator(); while (iter.hasNext()) { String item = iter.next(); if (item.equals(target)) { iter.remove(); } } }
利用 copyOnWrite容器。copyOnWrite容器即写时复制的容器。通俗的理解是当我们往一个容器添加元素的时候,不直接往当前容器添加,而是先将当前容器进行copy,复制出一个新的容器,然后新的容器里添加元素,添加完元素之后,再将原容器的引用指向新的容器。
这样做的好处是我们可以对copyOnWrite容器进行并发的读,而不需要加锁,因为当前容器不会添加任何元素。所以copyOnWrite容器也是一种读写分离的思想,读和写不同的容器。
public static List<String> remove(ArrayList<String> list, String target) { copyOnWriteArrayList<String> cowList = new copyOnWriteArrayList<String>(list); for (String item : cowList) { if (item.equals(target)) { cowList.remove(item); } } return cowList; }
注意:
1、使用copyOnWriteArrayList的好处是我们不仅仅可以删除,也可以在遍历的时候添加新元素。
2、以上方法并没有修改参数list,而是返回copyOnWriteArrayList给调用者,也就是说copyOnWriteArrayList并不修改构造它的List,而是自己内部维护着一个List,这一点要特别注意。
3、copyOnWriteArrayList不是ArrayList的子类,但它实现了List接口。
五、增强for循环删除
增强for循环中删除元素后继续循环会报 java.util.ConcurrentModificationException 异常,因为元素在使用的时候发生了并发的修改,导致异常抛出,但是删除完毕马上使用break语句跳出循环,则不会触发报错,所以它适合删除至多1个元素。
public static void remove(List<String> list, String target) { for (String item : list) { if (item.equals(target)) { list.remove(item); break; } } }
六、stream API filter
Java8引入的stream API带来了新的比较简洁的删除List元素的方法filter,该方法不会改变原List对象,须返回新的对象,下面的例子演示了如何使用stream删除集合中的*元素。
List<String> list = new ArrayList<>(); list.add(a); list.add(b); list.add(*); list.add(c); list.add(*); List<String> result = list .stream() .filter(item -> !*.equals(item)) .collect(Collectors.toList());
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。