javaの配列オブジェクトの重複をfil타ーするには
JavaではStreamのdistinct()メソッドで、重複した配列オブジェクトをフィルターできます。
以下に簡単なサンプルコードを示します:
import java.util.Arrays;
import java.util.List;
import java.util.stream.Collectors;
public class Main {
public static void main(String[] args) {
// 创建一个包含重复的数组对象的列表
List<Person> personList = Arrays.asList(
new Person("Alice", 25),
new Person("Bob", 30),
new Person("Alice", 25),
new Person("Charlie", 35)
);
// 使用 Stream 的 distinct() 方法来过滤重复的数组对象
List<Person> distinctPersonList = personList.stream()
.distinct()
.collect(Collectors.toList());
// 输出过滤后的结果
for (Person person : distinctPersonList) {
System.out.println(person.getName() + " - " + person.getAge());
}
}
}
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;
}
// 重写 equals() 方法,用于判断两个 Person 对象是否相等
@Override
public boolean equals(Object obj) {
if (this == obj) {
return true;
}
if (obj == null || getClass() != obj.getClass()) {
return false;
}
Person person = (Person) obj;
return age == person.age && name.equals(person.name);
}
// 重写 hashCode() 方法,用于计算 Person 对象的哈希值
@Override
public int hashCode() {
return Objects.hash(name, age);
}
}
上記のコードでは、Personというクラスを定義し、equals()とhashCode()メソッドをオーバーライドしてオブジェクトの同一性とハッシュ値の計算を行い、重複したPersonオブジェクトを含むリストpersonListを作成し、Streamのdistinct()メソッドを使って重複したオブジェクトを除去しています。最終的に、除去後の結果を出力します。
結果は出力された。
Alice - 25
Bob - 30
Charlie - 35
重複した Person オブジェクトは除外されていることがわかります。