參閱:百度文庫(kù)“深刻理解hashcode()”http://wenku.baidu.com/view/a145d76aaf1ffc4ffe47ac7a.html 1。equals()和hashcode()方法都來(lái)自O(shè)bject類。 (1)Object類中的equals()方法比較的是兩個(gè)對(duì)象的內(nèi)存地址值是否相等:return (this==obj); (2)String/Double/Integer等封裝類覆寫了equals方法,比較的是內(nèi)容(基本數(shù)據(jù)類型比較的是值)是否相等。 (3)重寫equals方法必須遵循的準(zhǔn)則: a)反射性(reflexive):x.equals(x)必須返回true; b)對(duì)稱性(symmetric):如果x.equals(y)返回true,那么y.equals(x)必須返回true; c)類推性(transitive):如果x.equals(y)返回true,且y.equals(z)返回true,那么x.equals(z)必須返回true; d)一致性(consistent):如果x.equals(y)返回true,則只要x和y內(nèi)容不變,無(wú)論重復(fù)多少次的x.equals(y) 返回都是true; e)對(duì)于非空的x,x.equals(null)永遠(yuǎn)返回false,x.equals(與x類型不同的對(duì)象)永遠(yuǎn)返回false。 2。hashcode()方法是native的,即它是本地方法,與本地機(jī)器有關(guān)。可覆寫。 hashcode即依據(jù)特定算法(哈希算法即散列算法)得到對(duì)象存儲(chǔ)的物理地址(實(shí)際上可能并不是,這樣得到的地址有可能重復(fù))。 可用于collection類對(duì)象中元素的循環(huán)比較,提高效率。當(dāng)然比較兩個(gè)對(duì)象是否相同可直接使用equals方法 而不必使用hashcode,先比較hashcode,如果hashcode不等則對(duì)象肯定不相同,若相等再調(diào)用equals方法比較,以提高效率。 3。equals()與hashcode() (1)兩個(gè)對(duì)象相同,即equals()相等,則hashcode值肯定相等。 (2)兩個(gè)對(duì)象hashcode相等,他們不一定相同。 (3)equals()不相等的兩個(gè)對(duì)象,不能證明他們的hashcode一定相等;即equals不等,hashcode可能相等。 (4)hashcode不等,equals肯定不等。 |
|
來(lái)自: 漂泊的燕子 > 《Java基礎(chǔ)》