問題 可以直接根據(jù)hashCode()方法產(chǎn)生的值判斷兩個對象是否相等嗎? 解答 不能!根據(jù)Wikipedia(https://en./wiki/Java_hashCode())上對hashCode()方法的解釋,它會根據(jù)這個對象內(nèi)存儲的數(shù)據(jù)及對象的一些特征來做散列,并返回一個有符號的32位哈希值。從這解釋我們就可以看到,hashCode()方法返回的是一個散列值,而對于一個散列來說,不同的內(nèi)容也是可能會出現(xiàn)相同的散列值的。所以即使兩個對象的hashCode()返回的值一樣,也并不能代表兩個對象是相等的。要判斷兩個對象是否相等,還是需要equals()方法去做判斷。 發(fā)散思考 1.既然hashCode()不能判斷兩個對象是否相等,那hashCode()可以判斷兩個對象什么? 解答:兩個對象的hashCode()返回值相等,不能判斷這兩個對象是相等的。但是,兩個對象的hashCode()返回值不相等,則這兩個對象一定不相等。 2.hashCode()通常用在什么地方? 解答:hashCode()方法的主要作用是配合基于散列的集合進(jìn)行工作。也就是說,當(dāng)你把對象存儲到基于散列的集合的時候,就會用到這個哈希值來做插入和讀取的操作,以加快操作的速度。 |
|