Java中的Set集合介面實現插入對象不重複的原理,javaset

來源:互聯網
上載者:User

Java中的Set集合介面實現插入對象不重複的原理,javaset

在java的集合中,判斷兩個對象是否相等的規則是:

1)、判斷兩個對象的hashCode是否相等 。
      如果不相等,認為兩個對象也不相等,完畢 
      如果相等,轉入2)
(這一點只是為了提高儲存效率而要求的,其實理論上沒有也可以,但如果沒有,實際使用時效率會大大降低,所以我們這裡將其做為必需的。後面會重點講到這個問題。) 
2)、判斷兩個對象用equals運算是否相等 。
      如果不相等,認為兩個對象也不相等 
      如果相等,認為兩個對象相等(equals()是判斷兩個對象是否相等的關鍵)

 

對於一般類的對象(除String等封裝類型對象外):

若普通類沒有重寫hashcode()和equals()方法,,那麼其對象在比較時,是繼承的object類中的hashcode()方法,object類中的hashcode()方法是一個本地方法,對該方法的傳回值進行比較時,比較的是對象的地址(引用地址),使用new方法建立內容相同的對象,兩次產生的當然是不同的對象。除非重寫hashcode()方法。在object類中定義的equals()方法也是對對象地址的比較。一句話總結:若不重寫普通類的hashcode()和equals()方法,在Set集合中對象引用地址不一樣,對象即不重複。

 

對於String等對象(String、Integer、Double····等等):

由於這些封裝類本身已經重寫了hashcode()方法,並且重寫的方法的傳回值跟對象的內容相關,而不是跟引用地址相關。這些封裝類中的equals()方法同樣進行了重寫,比較的是對象的內容,而非引用地址。一句話總結:String等類的對象在集合中均比較他們的內容,內容相同則覆蓋已存在的對象。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.