91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

HashSet/TreeSet是怎么使用hashCode()和equal()方法的

發布時間:2021-12-31 16:15:24 來源:億速云 閱讀:187 作者:iii 欄目:編程語言

本篇內容主要講解“HashSet/TreeSet是怎么使用hashCode()和equal()方法的”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“HashSet/TreeSet是怎么使用hashCode()和equal()方法的”吧!

一. 問題

1. HashSet,TreeSet是如何使用hashCode()和equal()方法的

2. TreeMap,TreeSet中的對象何時以及為何要實現Comparable接口?

二. 回答:

1. HashSet是通過HashMap實現的,TreeSet是通過TreeMap實現的,只不過Set用的只是Map的key
2. Map的key和Set都有一個共同的特性就是集合的唯一性.TreeMap更是多了一個有序性.
3. hashCode和equal()是HashMap用的, 因為無需排序所以只需要關注定位和唯一性即可.
  a. hashCode是用來計算hash值的,hash值是用來確定hash表索引的.
  b. hash表中的一個索引處存放的是一張鏈表, 所以還要通過equal方法循環比較鏈上的每一個對象
      才可以真正定位到鍵值對應的Entry.
  c. put時,如果hash表中沒定位到,就在鏈表前加一個Entry,如果定位到了,則更換Entry中的value,并返回舊value

[@more@]d. 覆寫key的hashCode()和equal()時一定要注意,不要把它們和可變屬性關聯上,
      否則屬性變了之后hashCode會變,equal也會為false, 這樣在Map中就找不不到它了
      而且這樣的對象因為找不到它所以得不到釋放,這樣就變成了一個無效引用了(相當于內存泄漏).
4. 由于TreeMap需要排序,所以需要一個Comparator為鍵值進行大小比較.當然也是用Comparator定位的.

a. Comparator可以在創建TreeMap時指定,這時排序時使用Comparator.compare
  b. 如果創建時沒有指定Comparator,那么就會使用key.compareTo()方法,這就要求key必須實現Comparable接口.
  c. TreeMap是使用Tree數據結構實現的,所以使用compare接口就可以完成定位了.

到此,相信大家對“HashSet/TreeSet是怎么使用hashCode()和equal()方法的”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

射洪县| 上思县| 扬中市| 贡嘎县| 应城市| 叙永县| 峨眉山市| 盱眙县| 出国| 息烽县| 涿鹿县| 松滋市| 定日县| 朝阳区| 泽州县| 福安市| 永川市| 弥勒县| 广河县| 论坛| 顺平县| 桦川县| 平邑县| 六枝特区| 耿马| 荃湾区| 米林县| 望谟县| 来凤县| 铜山县| 军事| 龙川县| 灯塔市| 米泉市| 平武县| 灌南县| 麦盖提县| 名山县| 滕州市| 荃湾区| 新河县|