技术文摘
Java 中 HashSet 集合对自定义对象去重的实现方式
2024-12-31 11:09:57 小编
Java 中 HashSet 集合对自定义对象去重的实现方式
在 Java 编程中,HashSet 是一种常用的集合类型,它不允许存储重复的元素。然而,当处理自定义对象时,要实现 HashSet 对其的去重,需要一些特定的步骤和考虑因素。
自定义对象需要正确重写 hashCode 和 equals 方法。HashCode 方法用于计算对象的哈希值,而 equals 方法用于比较两个对象是否相等。如果这两个方法没有正确实现,HashSet 可能无法准确地识别重复的对象。
例如,假设我们有一个自定义的“Person”类:
public class Person {
private String name;
private int age;
// 构造函数、getter 和 setter 方法
@Override
public int hashCode() {
int result = name.hashCode();
result = 31 * result + age;
return result;
}
@Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null || getClass()!= obj.getClass())
return false;
Person other = (Person) obj;
return name.equals(other.name) && age == other.age;
}
}
在上述代码中,hashCode 方法结合了“name”和“age”的特征来计算哈希值,equals 方法则详细比较了两个“Person”对象的属性。
接下来,当我们将自定义的“Person”对象添加到 HashSet 中时:
HashSet<Person> personSet = new HashSet<>();
Person person1 = new Person("Alice", 25);
Person person2 = new Person("Bob", 30);
Person person3 = new Person("Alice", 25);
personSet.add(person1);
personSet.add(person2);
personSet.add(person3);
由于我们正确实现了 hashCode 和 equals 方法,HashSet 能够识别“person1”和“person3”是重复的对象,只会存储其中一个。
需要注意的是,HashCode 方法应该尽量保证不同的对象具有不同的哈希值,以提高 HashSet 的性能。而 equals 方法则必须准确地定义对象相等的条件。
通过正确重写自定义对象的 hashCode 和 equals 方法,我们可以有效地利用 HashSet 集合来实现对自定义对象的去重操作,从而提高程序的效率和准确性。
- Python 散点图:添加拟合线、显示拟合方程与 R 方的方法
- 互联网公司大规模涉足地摊经济 令人惊叹
- DinamicX 深度剖析:盲人如何实现在线购物?
- 2020 年十大开发者岗位
- 5 个神奇的 Python 数据科学软件包
- 5000 行 Python 代码与 60W 数据可视化,揭示知乎用户的隐秘
- 软件工程的困惑与思考
- Swift 中鲜为人知的特性:~= 运算符的解析
- Python 数据分析之 Pandas 初体验
- DeepMind 推出 Acme :轻松编写 RL 智能体的高效分布式强化学习算法框架
- 六种实用的程序员在线开发工具
- Python 除爬虫抓数据外的用途:监视和衡量网站性能
- 全面洞悉 BiLSTM 与 CRF 算法
- Gartner 有关建设数据中台的建议
- 在终端执行 Python 代码的 6 种方式,令人涨见识!