java List去重,根据多个字段属性去重

问题描述: 

如果我有一个A类,里面有5个字段,对于数组List<A> list,我想根据其中的2个字段来去重,如果2个字段都是一样的,只取最新的一条数据即可。

实现思路:

如果你有一个A类,并且想根据其中的两个字段进行去重,只保留最新的一条数据,那么你可以不定义一个新的类PersonId。在这种情况下,你可以使用Java中的Map来达到去重的效果。

你可以将A类中的两个字段作为键(key),将A类的对象作为值(value)。然后,遍历你的数据列表,将每个对象添加到Map中。如果Map中已经存在相同的键,则将原来的值替换为当前对象(假设最新的数据具有更高的优先级)。最后,你只需要从Map中获取值,就可以得到根据这两个字段去重后的最新数据。

示例代码:

import java.util.*;  
  
class A {  
    private String field1;  
    private String field2;  
    // 其他字段...  
      
    // 构造函数、getter和setter...  
}  
  
public class Main {  
    public static void main(String[] args) {  
        List<A> dataList = ... // 你的数据列表  
          
        Map<String, A> map = new HashMap<>();  
        for (A obj : dataList) {  
            String key = obj.getField1() + "," + obj.getField2(); // 根据两个字段生成键  
            if (!map.containsKey(key)) {  
                map.put(key, obj);  
            } else {  
                // 更新旧的数据(假设最新的数据具有更高的优先级)  
                map.put(key, obj);  
            }  
        }  
          
        // 从Map中获取去重后的数据列表  
        List<A> uniqueDataList = new ArrayList<>(map.values());  
          
        // 打印去重后的数据列表  
        for (A obj : uniqueDataList) {  
            // 处理数据...  
        }  
    }  
}

在上面的代码中,我们使用了一个字符串拼接的方式生成键(key),你可以根据自己的需求进行修改。此外,我们假设最新的数据具有更高的优先级,因此当遇到重复键时,会更新旧的数据。如果你希望根据其他规则进行去重,可以根据需要进行修改。

应该还有其他的方法。

Java中,使用Stream根据对象多个字段属性可以通过多种方式实现。 ### 写`equals`和`hashCode`方法 可以写实体类的`equals`和`hashCode`方法,使其根据多个字段来判断对象是否相等,然后使用`distinct()`方法进行。示例代码如下: ```java import java.util.ArrayList; import java.util.List; import java.util.stream.Collectors; class Person { private String name; private int age; public Person(String name, int age) { this.name = name; this.age = age; } public String getName() { return name; } public int getAge() { return age; } @Override public boolean equals(Object o) { if (this == o) return true; if (o == null || getClass() != o.getClass()) return false; Person person = (Person) o; return age == person.age && name.equals(person.name); } @Override public int hashCode() { return name.hashCode() + age; } @Override public String toString() { return "Person{name='" + name + "', age=" + age + "}"; } } public class Main { public static void main(String[] args) { List<Person> personList = new ArrayList<>(); personList.add(new Person("Alice", 20)); personList.add(new Person("Bob", 25)); personList.add(new Person("Alice", 20)); List<Person> distinctList = personList.stream() .distinct() .collect(Collectors.toList()); distinctList.forEach(System.out::println); } } ``` 在上述代码中,`Person`类写了`equals`和`hashCode`方法,根据`name`和`age`字段来判断对象是否相等。然后使用`stream().distinct().collect(Collectors.toList())`对列表进行操作。 ### 使用`TreeSet`和`Comparator` 可以使用`TreeSet`和`Comparator`来根据多个字段进行。示例代码如下: ```java import java.util.ArrayList; import java.util.Comparator; import java.util.List; import java.util.TreeSet; import java.util.stream.Collectors; class Student { private String name; private int age; public Student(String name, int age) { this.name = name; this.age = age; } public String getName() { return name; } public int getAge() { return age; } @Override public String toString() { return "Student{name='" + name + "', age=" + age + "}"; } } public class Main2 { public static void main(String[] args) { List<Student> studentList = new ArrayList<>(); studentList.add(new Student("Tom", 18)); studentList.add(new Student("Jerry", 22)); studentList.add(new Student("Tom", 18)); List<Student> distinctList = studentList.stream() .collect(Collectors.collectingAndThen( Collectors.toCollection(() -> new TreeSet<>(Comparator.comparing(Student::getName).thenComparing(Student::getAge))), ArrayList::new )); distinctList.forEach(System.out::println); } } ``` 在上述代码中,使用`Collectors.collectingAndThen`结合`TreeSet`和`Comparator`,`Comparator.comparing(Student::getName).thenComparing(Student::getAge)`根据`name`和`age`字段进行比较,实现
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值