ArrayList去重的几种方法

第一种:通过LinkedHashSet来解决,LinkedHashSet是有序不可重复的,可以把ArrayList传入LinkedHashSet中

控制台输出:

[1, 2, 2, 3, 3, 1, 2]
[1, 2, 3]

 第二种:使用Java8的新特性stream的distinct()方法来实现

控制台输出:

[1, 2, 2, 3, 3, 1, 2]
[1, 2, 3]

第三种:使用contains()方法去重

控制台输出:

[1, 2, 2, 3, 3, 1, 2]
[1, 2, 3]

第四种: 利用HashSet(无序唯一)的特性

控制台输出:

[1, 2, 2, 3, 3, 1, 2]
[1, 2, 3]

 当然还有其它方式,仅供参考,谢谢

  • 8
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Java集合按照某个字段去重有多种做法,以下是其中的几种: 1. 重写对象的 equals 和 hashCode 方法 这种方法是最常见的做法,需要重写对象的 equals 和 hashCode 方法,根据指定字段的值来判断两个对象是否相等,然后使用 HashSet 去重。 示例代码: ```java public class Person { private String id; private String name; public Person(String id, String name) { this.id = id; this.name = name; } // 重写 equals 和 hashCode 方法,根据 id 值判断两个对象是否相等 @Override public boolean equals(Object obj) { if (this == obj) { return true; } if (obj == null || getClass() != obj.getClass()) { return false; } Person person = (Person) obj; return Objects.equals(id, person.id); } @Override public int hashCode() { return Objects.hash(id); } } List<Person> list = new ArrayList<>(); list.add(new Person("1", "张三")); list.add(new Person("2", "李四")); list.add(new Person("1", "王五")); Set<Person> set = new HashSet<>(list); System.out.println(set); ``` 输出结果为: ``` [Person{id='1', name='张三'}, Person{id='2', name='李四'}] ``` 可以看到,根据 id 值去重成功,保留了 id 值为 1 和 2 的两个对象。 2. 使用 Java 8 的 Stream API Java 8 的 Stream API 提供了 distinct 方法可以去重,并且可以根据指定字段去重。 示例代码: ```java List<Person> list = new ArrayList<>(); list.add(new Person("1", "张三")); list.add(new Person("2", "李四")); list.add(new Person("1", "王五")); List<Person> result = list.stream() .filter(distinctByKey(Person::getId)) .collect(Collectors.toList()); System.out.println(result); ``` 输出结果同上面的示例,根据 id 值去重成功。 其中,`distinctByKey` 是一个自定义的方法,根据指定的属性值去重: ```java public static <T> Predicate<T> distinctByKey(Function<? super T, Object> keyExtractor) { Set<Object> seen = ConcurrentHashMap.newKeySet(); return t -> seen.add(keyExtractor.apply(t)); } ``` 3. 使用 TreeSet TreeSet 是一个有序的集合,可以根据指定字段进行排序和去重。需要实现 Comparable 接口,并重写 compareTo 方法。 示例代码: ```java public class Person implements Comparable<Person> { private String id; private String name; public Person(String id, String name) { this.id = id; this.name = name; } // 根据 id 值比较大小 @Override public int compareTo(Person o) { return this.id.compareTo(o.id); } } List<Person> list = new ArrayList<>(); list.add(new Person("1", "张三")); list.add(new Person("2", "李四")); list.add(new Person("1", "王五")); Set<Person> set = new TreeSet<>(list); System.out.println(set); ``` 输出结果同上面的示例,根据 id 值去重成功。 需要注意的是,TreeSet 去重是根据 compareTo 方法的返回值进行的,如果 compareTo 方法实现不正确,可能会出现去重失败的情况。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值