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