java 去重的集合_Java集合去重的几种方法

一、基础数据类型集合去重:

例:String

public static void main(String[] args) {

List list = new ArrayList<>();

list.add("c");

list.add("c");

list.add("a");

list.add("a");

list.add("b");

//1.set集合去重,不改变原有的顺序

pastLeep1(list);

//2.遍历后判断赋给另一个list集合 不改变原有的顺序

pastLeep2(list);

//3.set去重 并按自然顺序排序

pastLeep3(list);

//4.set去重(缩减为一行)

pastLeep4(list);

//5.去重并按自然顺序排序

pastLeep5(list);

}

方法实现:

//1.set集合去重,不改变原有的顺序

public static void pastLeep1(List list){

System.out.println("list = [" + list.toString() + "]");

List listNew=new ArrayList<>();

Set set=new HashSet();

for (String str:list) {

if(set.add(str)){

listNew.add(str);

}

}

System.out.println("listNew = [" + listNew.toString() + "]");

}

//2.遍历后判断赋给另一个list集合 不改变原有的顺序

public static void pastLeep2(List list){

System.out.println("list = [" + list.toString() + "]");

List listNew=new ArrayList<>();

for (String str:list) {

if(!listNew.contains(str)){

listNew.add(str);

}

}

System.out.println("listNew = [" + listNew.toString() + "]");

}

//3.set去重 并按自然顺序排序

public static void pastLeep3(List list){

System.out.println("list = [" + list + "]");

Set set = new HashSet();

List listNew=new ArrayList<>();

set.addAll(list);

listNew.addAll(set);

System.out.println("listNew = [" + listNew + "]");

}

//4.set去重(缩减为一行) 并按自然顺序排序

public static void pastLeep4(List list){

System.out.println("list = [" + list + "]");

List listNew=new ArrayList<>(new HashSet(list));

System.out.println("listNew = [" + listNew + "]");

}

//5.去重并按自然顺序排序

public static void pastLeep5(List list){

System.out.println("list = [" + list + "]");

List listNew=new ArrayList<>(new TreeSet(list));

System.out.println("listNew = [" + listNew + "]");

}

二、对象根据指定属性去重

ListuserList = new ArrayList<>();

userList.add(new User(1,"小李","男"));

userList.add(new User(5,"小李","男"));

userList.add(new User(7,"小李","男"));

userList.add(new User(3,"小李","男"));

userList.add(new User(1,"小李","男"));

userList.add(new User(5,"小李","男"));

//6.对象 根据指定属性去重 并按自然顺序排序

System.out.println(removeDuplicateUser(userList));

//7. 根据指定属性去重 并按自然顺序排序2

System.out.println(removeDuplicateUser2(userList));

//6.对象 根据指定属性去重 并按自然顺序排序

public static ArrayList removeDuplicateUser(List users) {

Set set = new TreeSet(new Comparator() {

@Override

public int compare(User o1, User o2) {

return new Integer(o1.getId()).compareTo(new Integer(o2.getId()));

}

});

set.addAll(users);

return new ArrayList(set);

}

//7. 根据指定属性去重 并按自然顺序排序2

public static List removeDuplicateUser2(List list){

List unique = list.stream().collect(

collectingAndThen(

toCollection(() -> new TreeSet<>(comparingLong(User::getId))), ArrayList::new)

);

return unique;

}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
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 方法实现不正确,可能会出现去失败的情况。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值