以下是一个示例代码,可以比较两个对象数组并去除重复项:
import java.util.ArrayList;
import java.util.HashSet;
import java.util.List;
import java.util.Set;
public class Main {
public static void main(String[] args) {
// 创建两个对象数组
Person[] arr1 = {new Person("John", 25), new Person("Alice", 30), new Person("Bob", 35)};
Person[] arr2 = {new Person("Alice", 30), new Person("David", 40), new Person("Bob", 35)};
// 将对象数组转换为列表
List list1 = new ArrayList<>();
for (Person person : arr1) {
list1.add(person);
}
List list2 = new ArrayList<>();
for (Person person : arr2) {
list2.add(person);
}
// 创建一个集合用于存储不重复的对象
Set uniqueSet = new HashSet<>();
// 将list1中的对象添加到uniqueSet中
uniqueSet.addAll(list1);
// 遍历list2,将不在uniqueSet中的对象添加到uniqueSet中
for (Person person : list2) {
if (!uniqueSet.contains(person)) {
uniqueSet.add(person);
}
}
// 将uniqueSet转换为数组
Person[] uniqueArr = new Person[uniqueSet.size()];
uniqueSet.toArray(uniqueArr);
// 打印去重后的数组
for (Person person : uniqueArr) {
System.out.println(person.getName() + " - " + person.getAge());
}
}
static 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;
}
}
}
此示例中,我们首先将两个对象数组转换为列表,然后使用HashSet存储不重复的对象。我们将第一个列表中的所有对象添加到HashSet中,然后遍历第二个列表,将不在HashSet中的对象添加到HashSet中。最后,我们将HashSet转换回数组,并打印去重后的数组。
上一篇:比较两个对象数组并匹配值