在Hashtable,HashMap,HashSet中, 根据hashcode来决定是否两个对象是否相同,如果相同的话则会覆盖已经存在的对象。
所以创建类的时候,如果重写了equals方法,记得一定也要重写hashcode方法。因为在Hashtable,HashMap,HashSet中并不是根据equals来决定对象是否是同一个,而是根据hashcode。
基本原则是:如果两个对象是equal的,那么要保证他们的hashcode也是一致的。
除此之外hashcode并无多大作用。
举例:Student类 , equals和hashcode方法都重写了。
package hashcode; import java.util.HashMap; import java.util.HashSet; import java.util.Hashtable; public class Student { private int age; private String name; public int getAge() { return age; } public void setAge(int age) { this.age = age; } public String getName() { return name; } public void setName(String name) { this.name = name; } /** * hashcode is used in hashset, hashmap, hashtable. if key's hashcode is the * same, the key will be overided. */ public int hashCode() { return this.age + this.name.hashCode(); } public boolean equals(Object obj) { if (obj == null || !(obj instanceof Student)) { return false; } if (this == obj) { return true; } Student s = (Student) obj; if (s.getAge() == this.getAge() && s.getName().equals(this.getName())) { return true; } else { return false; } } public Student() { } public Student(String name, int age) { setName(name); setAge(age); } /** * @param args */ public static void main(String[] args) { Student s1 = new Student("xiaohong", 11); Student s2 = new Student("xiaohong", 11); System.out.println(s1.hashCode()); //265195626 System.out.println(s2.hashCode()); //265195626 if (s1.equals(s2)) { System.out.println("s1 equals s2");//This line prints. } else { System.out.println("s1 doesn't equal s2"); } HashMap<Student, String> map = new HashMap<Student, String>(); map.put(s1, "ok"); map.put(s2, "nok"); System.out.println(map.get(s1));//"nok", s1 is overided by s2. System.out.println(map.get(s2));//"nok" Hashtable<Student, String> table = new Hashtable<Student, String>(); table.put(s1, "ok"); table.put(s2, "nok"); System.out.println(map.get(s1));//"nok", s1 is overided by s2. System.out.println(map.get(s2));//"nok" HashSet<Student> set = new HashSet<Student>(); Student[] setArray = new Student[2]; set.add(s1); set.add(s2); for (Student s : set.toArray(setArray)) { if (s != null) System.out.println(s.getName() + s.getAge()); } // print only one element. s1 is overied by s2. } }
假如只重写equals方法,而不重写hashcode方法,那么在hashtable,hashSet,hashMap中,这两个本来是equal的Student对象也会被认为是不同的对象而分别存放。
相关推荐
Java集合中有两类,一类是List,一类是Set他们之间的区别就在于List集合中的元素师有序的,且可以重复,而Set集合中元素是无序不可重复的。...hashCode提供了解决方案。怎么实现?我们先看hashCode的源码(Object)。
Java 中 HashCode 作用 HashCode 在 Java 中扮演着非常重要的角色,它对于一个对象的重要性不言而喻。本文将详细介绍 HashCode 的作用和重要性,为读者提供一个深入了解 HashCode 的机会。 HashCode 的作用 在 ...
"Java中Hashcode的作用" Hashcode是Java编程语言中一个非常重要的概念,它在equals方法中扮演着关键角色。在Java中,每个对象都具有一个独特的Hashcode,它可以用来标识对象的身份。但是Hashcode是什么?它是如何...
### hashCode的作用 在Java编程语言中,`hashCode`方法是一个重要的概念,主要用于对象的查找与存储,尤其是在集合框架中有着广泛的应用。为了更好地理解`hashCode`的作用及其在实际开发中的重要性,我们可以从以下...
以下是关于HashCode的官方文档定义: hashcode方法返回该对象的哈希码值。支持该方法是为哈希表提供一些优点,例如,java.util.Hashtable 提供的哈希表。 hashCode 的常规协定是: 在Java应用程序执行期间...
hashCode 的作用 hashCode 的主要作用是用于查找和排序。在查找和排序的过程中,我们需要快速地定位到目标对象,而 hashCode 正是这个过程的关键。例如,在内存中有 8 个位置,分别是 0 1 2 3 4 5 6 7,我们可以...
#### 一、HashCode 的基本概念与作用 在 Java 编程语言中,`HashCode` 是一个非常重要且基础的概念。简单来说,`HashCode` 是一个整数值,用于快速定位对象的位置。在 Java 中,每一个对象都有一个默认的 `HashCode...
这两个方法在处理对象比较和集合操作时起着至关重要的作用。当我们创建自定义类并需要对对象进行精确比较时,通常需要重写这些方法。以下是对`equals()` 和 `hashCode()` 方法的详细解释及其重写的重要性。 **1. ...
总结来说,`hashCode()`在Java和其他编程语言中起着关键的作用,它是高效数据结构如哈希表能够正常工作的重要组成部分。理解和正确实现`hashCode()`是每个程序员必备的技能之一。通过合理设计和优化`hashCode()`方法...
PPT浅析hashcode定义和作用;和简单的代码演示PPT.很简单的
在Java编程语言中,`hashCode()`和`equals()`方法是对象身份验证的关键组成部分,它们...这两个方法在Java编程中起着至关重要的作用,尤其是在处理集合类和数据结构时。了解并正确使用它们能够确保程序的正确性和效率。
`hashCode()`的主要作用在于生成一个整数,这个整数通常用来表示对象的一个哈希值。在Java集合框架中,特别是`HashSet`、`HashMap`等基于哈希表的数据结构中,`hashCode()`扮演着至关重要的角色。 **1.1 `hashCode...
在Java编程语言中,`equals()` 和 `hashCode()` 方法是对象的基本组成部分,它们在很多场景下都发挥着至关重要的作用。这两个方法与对象的相等性比较和哈希表(如HashMap、HashSet)的运作紧密相关。这篇博客将深入...
9. **HashMap的hashcode作用**: 在HashMap中,hashCode用于计算存储位置,重写hashCode方法可以优化哈希表的性能,避免哈希冲突。 10. **ArrayList、LinkedList、Vector的区别**: - ArrayList基于动态数组,...
本篇将深入探讨ArrayList与HashSet的区别,并分析Hashcode在其中的作用。 ArrayList是基于动态数组实现的,它提供了按索引访问元素的能力,就像在数组中一样。由于内部维护了一个数组,ArrayList保证了元素的顺序性...
`hashCode()` 的作用是为对象生成一个唯一的整数值,这个值通常被用来快速定位对象在哈希表(如 `HashSet` 或 `HashMap`)中的位置。`hashCode()` 的设计必须满足以下条件: 1. 相等的对象必须具有相同的哈希码:...
有许多人学了很长时间的Java,但一直不明白hashCode方法的作用以及equals()和==的区别,我来解释一下吧。首先,想要明白hashCode的作用,你必须要先知道Java中的集合。总的来说,Java中的集合(Collection)有两类,...
该方法的主要作用是返回一个整数,这个整数通常被用来作为哈希表中元素的索引。 #### 1.1 哈希算法简介 哈希算法是一种将任意长度的数据映射为固定长度的算法。简单来说,哈希算法就是将输入数据转换为一个特定的...