java 删除list中符合条件的对象(几种方法,避免入坑)

一、首先list遍历方法有那么几种:使用for循环、iterator、还有就是lambda表达式循环

1、首先创建一个测试类

class User2{
        Integer id;
        String name;

        public User2(Integer id, String name) {
            this.id = id;
            this.name = name;
        }

        public Integer getId() {
            return id;
        }

        public void setId(Integer id) {
            this.id = id;
        }

        public String getName() {
            return name;
        }

        public void setName(String name) {
            this.name = name;
        }

        @Override
        public String toString() {
            return "User2{" +
                    "id=" + id +
                    ", name='" + name + '\'' +
                    '}';
        }
    }

2、第一种遍历循环:fori循环

 @Test
    public void forTest(){
       List<User2> list = new ArrayList<>();
        list.add(new User2(1,"张三1"));
        list.add(new User2(2,"张三2"));
        list.add(new User2(3,"张三3"));
        list.add(new User2(5,"张三4"));
        list.add(new User2(5,"张三5"));
        list.add(new User2(6,"张三6"));
        list.add(new User2(7,"张三7"));
        for (int i = 0; i < list.size(); i++) {
            User2 user = list.get(i);
            if(list.get(i).getId() == 5){
                list.remove(user);
            }
        }
        System.out.println(list);
    }

执行结果为:

[User2{id=1, name='张三1'}, User2{id=2, name='张三2'}, User2{id=3, name='张三3'}, User2{id=5, name='张三5'}, User2{id=6, name='张三6'}, User2{id=7, name='张三7'}]

很明显,并没有达到我们预期的效果,因为下标是固定死的自增,但list的大小在随着删除元素不停的减小,并且后面的元素往前移了1位,所以后面的元素遍历不到。阿里巴巴编码规范中也有说明

3、第二种:foreach循环

@Test
    public void forTest(){
        List<User2> list = new ArrayList<>();
        list.add(new User2(1,"张三1"));
        list.add(new User2(2,"张三2"));
        list.add(new User2(3,"张三3"));
        list.add(new User2(5,"张三4"));
        list.add(new User2(5,"张三5"));
        list.add(new User2(6,"张三6"));
        list.add(new User2(7,"张三7"));
        for (User2 user : list) {
            if(user.getId() == 5){
                list.remove(user);
            }
        }
         System.out.println(list);
    }

报出异常:java.util.ConcurrentModificationException,关于这个异常的原因,看了很多文章,基本上解释如下:ArrayList的父类AbstarctList中有一个域modCount,每次对集合进行修改(增添、删除元素)时modCount都会+1。

4、使用lambda表达式,这种方法是可以使用的,但是使用lambda先循环在从中删除的方式是不可行的,原因和foreach方法一样

 @Test
    public void forTest(){
        List<User2> list = new ArrayList<>();
        list.add(new User2(1,"张三1"));
        list.add(new User2(2,"张三2"));
        list.add(new User2(3,"张三3"));
        list.add(new User2(5,"张三4"));
        list.add(new User2(5,"张三5"));
        list.add(new User2(6,"张三6"));
        list.add(new User2(7,"张三7"));
        //可行
        list.removeIf(user -> user.getId() == 5);
        //不可行
        list.forEach(user2 -> {
            if(user2.getId() == 5){
                list.remove(user2);
            }
        });
        System.out.println(list);
    }

5、使用迭代器删除也是可以的

 @Test
    public void forTest(){
        List<User2> list = new ArrayList<>();
        list.add(new User2(1,"张三1"));
        list.add(new User2(2,"张三2"));
        list.add(new User2(3,"张三3"));
        list.add(new User2(5,"张三4"));
        list.add(new User2(5,"张三5"));
        list.add(new User2(6,"张三6"));
        list.add(new User2(7,"张三7"));
        Iterator iterator = list.iterator();
        while (iterator.hasNext()){
            User2 user2 = (User2) iterator.next();
            if(user2.getId() == 5){
                iterator.remove();
            }
        }
        System.out.println(list);
    }

执行结果:

[User2{id=1, name='张三1'}, User2{id=2, name='张三2'}, User2{id=3, name='张三3'}, User2{id=5, name='张三5'}, User2{id=6, name='张三6'}, User2{id=7, name='张三7'}]
  • 11
    点赞
  • 35
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
掌握集合的概念、体系结构、分类及使用场景 2)了解Set接口及主要实现类(HashSet、TreeSet) 3)了解List接口及主要实现类(ArrayList、LinkedList、Vector) 4)了解Map接口及主要实现类(HashMap、TreeMap、HashTable) 二、实验内容及步骤 1、编写程序练习将以下5个Person类的对象放在一个HashSet。 姓名:张三 身份证号:178880001 姓名:王五 身份证号:178880002 姓名:李四 身份证号:178880003 姓名:王五 身份证号:178880002 姓名:李四 身份证号:178880004 注意:因为Person类是自定义类,需要重写hashCode()方法和equals()方法,并规定只有姓名和身份证号都相等,则对象相等。 其计算哈希码的算法:(31 + ((name == null) ? 0 : name.hashCode()))*31 + id (注:name:Person对象的姓名,id:Person对象的身份证号) 主方法作如下测试: 1)创建一个可放置Person类对象的HashSet; 2)依次添加上述5个对象到HashSet; 3)把集合的元素打印出来(使用迭代器Iterator) 2、编写程序练习List集合的基本使用: 1) 创建一个只能容纳String对象名为names的ArrayList集合; 2)按顺序往集合添加5个字符串对象:"张三"、"李四"、"王五"、"马六"、"赵七"; 3)对集合进行遍历,分别打印集合的每个元素的位置与内容; 4)打印集合的大小,然后删除集合的第3个元素,并显示删除元素的内容,然后再打印目前集合第3个元素的内容,并再次打印集合的大小。 3、编写程序练习Map集合的基本使用: 1)创建一个只能容纳String对象的person的HashMap集合; 2)往集合添加5个"键-值"对象: "id"-"1"; "name"-"张三"; "sex"-"男"; "age"-"25"; "hobby"-"爱学Java" 3)对集合进行遍历,分别打印集合的每个元素的键与值; 4)打印集合的大小,然后删除集合的键为age的元素,并显示删除元素的内容,并再次打印集合的大小。 四、思考题 1、集合List、Set、Map有哪些不同? 2、为什么使用集合框架,而尽可能少用数组作为存储结构? 3、如何使用TreeSet实现第一题?

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值