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