java中list集合删除其中的某一个元素

方法一:Iterator 去除

//定义list
List<User> list = new ArrayList<>();
User  user1 = new User();  
User  user2 = new User(); 
user1.serName("111");
user2.serName("222"); 
list.add(user1);
list.add(user2);
//删除集合中某一元素值
Iterator<User> iterator = list.iterator();
while (iterator.hasNext()){
    User next = iterator.next();
    String name = next.getName();
    if (name.equals("222")){
        iterator.remove();
    }
}

缺点:虽然也能去除  但是列表改造成 Iterator 类型的了 ,还要转换。

方法二: stream 去除

//定义list
List<User> list = new ArrayList<>();
User  user1 = new User();  
User  user2 = new User(); 
user1.serName("111");
user2.serName("222"); 
list.add(user1);
list.add(user2);

//删除集合中某一元素值
list.stream().findFirst().map(vo -> {
    if (vo.getName().equals("222")){
        list.remove(vo);
    }
    return vo;
});

优点: 没有改变list格式并且更简洁。

缺点:remove的时候会再次遍历整个list来找出 这个元素,性能会有一定的损耗。

方法三: stream +索引 去除

//定义list
List<User> list = new ArrayList<>();
User  user1 = new User();  
User  user2 = new User(); 
user1.serName("111");
user2.serName("222"); 
list.add(user1);
list.add(user2);

//删除集合中某一元素值
IntStream.range(0,list.size()).filter(i->
    list.get(i).getName().equals("222")).
boxed().findFirst().map(i->list.remove((int)i));

其中boxed为装箱操作

更简洁,高效。

  • 9
    点赞
  • 43
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 3
    评论
掌握集合的概念、体系结构、分类及使用场景 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实现第一题?
### 回答1: 可以使用RedisTemplate的opsForList()方法获取List类型的操作对象,然后使用remove()方法根据索引删除指定元素,示例代码如下: redisTemplate.opsForList().remove("listKey", 1, "elementValue"); 其,"listKey"是要操作的List集合的键名,1表示删除第一个匹配的元素,"elementValue"是要删除的元素的值。 ### 回答2: 在使用RedisTemplate删除List集合的指定元素时,可以通过以下步骤实现: 1. 首先,需要获取RedisTemplate实例,并设置好对应的序列化方式。可以使用以下代码获取: ```java RedisTemplate<String, Object> redisTemplate = new RedisTemplate<>(); redisTemplate.setConnectionFactory(redisConnectionFactory); redisTemplate.setDefaultSerializer(new GenericJackson2JsonRedisSerializer()); redisTemplate.afterPropertiesSet(); ``` 这里使用了Jackson2JsonRedisSerializer作为默认的序列化方式,可以根据实际情况选择合适的序列化方式。 2. 接下来,需要使用RedisTemplate的`boundListOps(key)`方法获取操作指定键值的列表对象。其,key为存储该List的键值。 ```java BoundListOperations<String, Object> boundListOps = redisTemplate.boundListOps("list_key"); ``` 3. 然后,可以使用RedisTemplate的`remove(key, count, value)`方法从List集合删除指定元素。其,count参数为删除的数量,可以是负数,表示从尾部开始删除;value参数为要删除的元素。 ```java boundListOps.remove("list_key", 1, "要删除的元素"); ``` 这里的count参数为1,表示删除指定元素的第一个匹配项,若存在多个相同的元素,可以根据实际情况进行调整。 综上所述,使用RedisTemplate可以根据指定索引删除List集合的某一个元素。 ### 回答3: 使用RedisTemplate删除list集合的某个元素,可以使用内置的remove方法来实现。具体步骤如下: 1. 首先,通过RedisTemplate的opsForList方法获取到指定list集合的操作对象。 ```java ListOperations<String, String> listOps = redisTemplate.opsForList(); ``` 2. 接下来,使用listOps的remove方法来删除指定元素。该方法接受三个参数:集合的key、要删除的元素、以及要删除的数量。 ```java Long removedCount = listOps.remove("listKey", "要删除的元素", 1); ``` 上述示例,我们传入了集合的key为"listKey",要删除的元素为"要删除的元素",数量为1。如果该元素存在且删除成功,则返回删除的数量。如果该元素不存在,则返回0。 3. 最后,我们可以根据返回的删除数量来确定删除是否成功。 ```java if (removedCount > 0) { System.out.println("成功删除了" + removedCount + "个元素"); } else { System.out.println("该元素不存在,删除失败"); } ``` 以上就是使用RedisTemplate根据指定索引删除list集合个元素的步骤。需要注意的是,Redis的List数据结构是有序的,可以通过索引访问和操作,但是删除操作需要通过先查询元素值,再删除的方式实现。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Trouble-Solver

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值