HashSet通过hashCode和equals方法判断重复,需重写这两个方法以确保去重正确;对于自定义类如Person,必须实现一致的equals和hashCode逻辑,否则可能导致去重失败或集合异常。

在Java中,HashSet 是一个基于哈希表实现的Set接口集合,它不允许存储重复元素。这使得 HashSet 成为去除重复数据的常用工具。只要正确使用,它可以高效地完成去重任务。
HashSet 判断两个对象是否重复,依赖于对象的 equals() 和 hashCode() 方法。当向 HashSet 添加一个元素时:
因此,为了确保去重有效,存入 HashSet 的对象必须正确重写这两个方法,尤其是自定义类。
对于 Integer、String 等 JDK 内置类,equals 和 hashCode 已经实现良好,可直接使用:
立即学习“Java免费学习笔记(深入)”;
Set<String> names = new HashSet<>();
names.add("Alice");
names.add("Bob");
names.add("Alice"); // 重复,不会添加
<p>System.out.println(names); // 输出: [Alice, Bob]</p>结果中只保留唯一值,重复的 "Alice" 被自动过滤。
假设有一个 Person 类,我们希望根据姓名和年龄判断是否重复:
class Person {
private String name;
private int age;
<pre class='brush:java;toolbar:false;'>public Person(String name, int age) {
this.name = name;
this.age = age;
}
@Override
public boolean equals(Object o) {
if (this == o) return true;
if (!(o instanceof Person)) return false;
Person person = (Person) o;
return age == person.age && name.equals(person.name);
}
@Override
public int hashCode() {
int result = name != null ? name.hashCode() : 0;
result = 31 * result + age;
return result;
}}
此时将多个 Person 对象加入 HashSet,相同姓名和年龄的只会保留一份:
Set<Person> people = new HashSet<>();
people.add(new Person("Tom", 25));
people.add(new Person("Tom", 25)); // 重复
people.add(new Person("Jerry", 20));
<p>System.out.println(people.size()); // 输出: 2</p>使用 HashSet 去重时,注意以下几点能避免常见问题:
基本上就这些。掌握 hashCode 和 equals 的作用机制,再结合实际场景选择合适的 Set 实现,就能高效、稳定地完成去重任务。不复杂但容易忽略细节。
以上就是在Java中如何使用HashSet去除重复元素_HashSet集合实践经验的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号