Java中Object有一個方法: public native int hashcode();
1. hashcode()方法的作用
hashcode()方法主要配合基于散列的集合一起使用,比如HashSet、HashMap、HashTable。
當集合需要添加新的對象時,先調用這個對象的hashcode()方法,得到對應的hashcode值,實際上hashmap中會有一個table保存已經存進去的對象的hashcode值,如果table中沒有改hashcode值,則直接存入,如果有,就調用equals方法與新元素進行比較,相同就不存了,不同就存入。
2. equals和hashcode的關系
- 如果equals為true,hashcode一定相等;
- 如果equals為false,hashcode不一定不相等;
- 如果hashcode值相等,equals不一定相等;
- 如果hashcode值不等,equals一定不等;
3. 重寫equals方法時,一定要重寫hashcode方法
4. 通俗解釋
1. hashcode是用來查找的,如果你學過數據結構就應該知道,在查找和排序這一章有 例如內存中有這樣的位置 0 1 2 3 4 5 6 7 而我有個類,這個類有個字段叫ID,我要把這個類存放在以上8個位置之一,如果不用hashcode而任意存放,那么當查找時就需要到這八個位置里挨個去找,或者用二分法一類的算法。 但如果用hashcode那就會使效率提高很多。
我們這個類中有個字段叫ID,那么我們就定義我們的hashcode為ID%8,然后把我們的類存放在取得得余數那個位置。比如我們的ID為9,9除8的余數為1,那么我們就把該類存在1這個位置,如果ID是13,求得的余數是5,那么我們就把該類放在5這個位置。這樣,以后在查找該類時就可以通過ID除 8求余數直接找到存放的位置了。
2. 但是如果兩個類有相同的hashcode怎么辦那(我們假設上面的類的ID不是唯一的),例如9除以8和17除以8的余數都是1,那么這是不是合法的。
回答是:可以這樣。那么如何判斷呢?在這個時候就需要定義 equals了。 也就是說,我們先通過 hashcode來判斷兩個類是否存放某個桶里,但這個桶里可能有很多類,那么我們就需要再通過 equals 來在這個桶里找到我們要的類。
那么重寫了equals(),為什么還要重寫hashCode()呢?想想,你要在一個桶里找東西,你必須先要找到這個桶啊,你不通過重寫hashcode()來找到桶,光重寫equals()有什么用啊。