亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

Java中 判斷集合中的元素相等的依據 詳細解析

2019-11-14 08:50:21
字體:
來源:轉載
供稿:網友

我們經常使用的集合如ArrayList,LinkedList,Vector, **你在調用contains()方法的時候, 或者是你在根據對象移除元素 remove(Object o) 你知道他們是如何判斷集合中的元素是否 是相等的嗎**? 接下來我們跟著源碼去詳細探究一下 數據數據結構不同判斷的依據就不同,我們先來看一下List類的判斷依據.

先簡單的了解一下 List類 : 有序,可以有重復元素。

ArrayList 底層是一個對象數組 PRivate transient Object[] elementData; LinkedList 屬于鏈式數據結構,底層用的是一個Node類的節點,包括指針域和數據域.

private static class Node { E item; Node next; Node prev;

Node(Node<E> prev, E element, Node<E> next) { this.item = element; this.next = next; this.prev = prev; }}

ArrayList LinkedList他們都是線程不同步的 Vector非常類似ArrayList,但是Vector是同步的。, ArrayList LinkedList多線程訪問會拋出 ConcurrentModificationException。如果想使他們線程同步的可以使用 Collections.synchronizedList 方法將該集合“包裝”起來

回歸正題

我們想知道他們如何判斷集合元素是否相等,我們應該想到的是contains(Object o)方法,接下來我們看一下contains(Object o)方法

public boolean contains(Object o) { return indexOf(o) >= 0; }

他的方法內部調用了indexOf(o)這個方法,我們繼續追蹤看一下indexOf(o)方法

public int indexOf(Object o) { if (o == null) { for (int i = 0; i < size; i++) if (elementData[i]==null) return i; } else { for (int i = 0; i < size; i++) if (o.equals(elementData[i])) return i; } return -1; }

看到這里我們應該能明白了 先判斷要查找的元素是否為空,不為空的話就調用equals方法.由此我們得到一個結論 List類中判斷元素是否相等依賴的是equals方法.

set類 : 無序,不允許重復

HashSet : 此實現不是同步的 我們知道HashSet它不允許出現重復元素,他是如何保證元素唯一的呢,我們應該首先想到的是看他的add()方法 如下

public boolean add(E e) { return map.put(e, PRESENT)==null; } 這里出現了一個map我們找找看看他是什么

我們在上面看到了他的定義

private transient HashMap<E,Object> map;

現在我們知道了HashSet的內部其實是一個HashMap來維護的,眾所周知HashMap的鍵是不允許有相同的,不用說HashMap的鍵就是HashSet的值,接下來我們只需要知道HashMap的鍵是如何保證唯一的就行了

我們就要追蹤HashMap的添加元素方法 put(K key, V value)

public V put(K key, V value) { if (table == EMPTY_TABLE) { inflateTable(threshold); } if (key == null) return putForNullKey(value); int hash = hash(key); int i = indexFor(hash, table.length); for (Entry<K,V> e = table[i]; e != null; e = e.next) { Object k; if (e.hash == hash && ((k = e.key) == key || key.equals(k))) { V oldValue = e.value; e.value = value; e.recordaccess(this); return oldValue; } }

雖然有點麻煩我們只需要仔細看看 一定可以看明白 抓住最重要的一句

e.hash == hash && ((k = e.key) == key || key.equals(k))

現在我們也知道了HashSet 和HaspMap 保證元素唯一的辦法是 先比較兩個元素的哈希值,如果哈希值相等,在比較元素的地址是否相同,或者調用兩個元素的equals方法如果哈希值不同,就根本不用在比較了.


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
色偷偷噜噜噜亚洲男人的天堂| 国内精久久久久久久久久人| 国产经典一区二区| 亚洲黄色www| 亚洲欧美中文日韩v在线观看| 亚洲欧洲在线免费| 亚洲精品网址在线观看| 97香蕉超级碰碰久久免费的优势| 日韩欧美极品在线观看| 欧美日韩免费一区| 成年无码av片在线| 久久久精品2019中文字幕神马| 免费av一区二区| 久久av.com| 欧美床上激情在线观看| 日本精品免费观看| 91天堂在线视频| 久久久久国产精品一区| 91沈先生作品| 亚洲欧美另类在线观看| 日韩av电影院| 91亚洲国产成人久久精品网站| 不卡av电影在线观看| 中文字幕久久亚洲| 亚洲欧美日韩一区二区三区在线| 色久欧美在线视频观看| 亚洲最大的成人网| 亚洲精选中文字幕| 国产精品十八以下禁看| 久久久久久久久久国产精品| 国产精品日韩欧美| 国内精品久久久久久| 欧美人与物videos| 国产午夜精品麻豆| 日本电影亚洲天堂| 精品久久久视频| 久久99青青精品免费观看| 亚洲成人av片| 国产精品国模在线| 亚洲天堂影视av| 91精品视频在线播放| 欧美激情在线观看| 久久99亚洲热视| 综合欧美国产视频二区| 国产热re99久久6国产精品| 国产精品成人aaaaa网站| 国产九九精品视频| 丁香五六月婷婷久久激情| 欧美性受xxxx白人性爽| 91网站免费看| 精品福利免费观看| 久久久精品久久| 51色欧美片视频在线观看| 日韩精品视频在线观看网址| 欧美裸体xxxx极品少妇| 欧美性高跟鞋xxxxhd| 蜜臀久久99精品久久久无需会员| 亚洲风情亚aⅴ在线发布| 久久99精品视频一区97| 亚洲高清免费观看高清完整版| 国产在线视频欧美| 国产精品午夜一区二区欲梦| 久久天天躁狠狠躁老女人| 国产日韩精品在线播放| 国产欧美亚洲精品| 亚洲成av人影院在线观看| 亚洲黄色在线观看| 久久91亚洲人成电影网站| 色妞色视频一区二区三区四区| 狠狠色狠色综合曰曰| 91性高湖久久久久久久久_久久99| 欧美成人四级hd版| 日韩专区中文字幕| 国产精品永久免费| 日韩一区在线视频| 欧美精品九九久久| 精品福利在线观看| 成人女保姆的销魂服务| 国产一区二区三区18| 国产精品视频网站| 日韩中文字幕精品| 国产91精品久久久| 日韩在线免费高清视频| 日韩国产中文字幕| 午夜精品久久久久久久久久久久久| 亚洲美女精品成人在线视频| 91精品国产乱码久久久久久蜜臀| 九九热这里只有在线精品视| 欧美激情va永久在线播放| 国产精品96久久久久久| 狠狠色香婷婷久久亚洲精品| 九九久久久久久久久激情| 一区二区在线免费视频| 亚洲91精品在线| 久久视频在线观看免费| 久久精品影视伊人网| 国产精品久久国产精品99gif| 国产不卡视频在线| 自拍偷拍亚洲精品| 亚洲视频一区二区三区| 日本高清久久天堂| 91精品国产色综合| 自拍偷拍免费精品| 亚洲国产精品va在线看黑人动漫| 欧美一级bbbbb性bbbb喷潮片| 久久久久久久久综合| 这里只有视频精品| 成人中文字幕+乱码+中文字幕| 国产精品三级网站| 国产精品久久久久久久久免费看| 久久久999精品| 亚洲天堂久久av| 伊人伊成久久人综合网站| 夜色77av精品影院| 欧美日韩一区免费| 久久久久国色av免费观看性色| 国产女精品视频网站免费| 欧美一区二区大胆人体摄影专业网站| 91在线视频成人| 久久激情五月丁香伊人| 亚洲男人天堂古典| 国产精品一区二区三区久久| 91高潮在线观看| 日韩在线播放视频| 国产成人精品在线| 精品久久久久久久久久久久| 精品呦交小u女在线| 国产日韩精品入口| 欧美午夜激情在线| 日韩在线观看网站| 欧美日韩亚洲视频| 91精品久久久久久久久| 北条麻妃在线一区二区| 久久久亚洲网站| 精品免费在线视频| 亚洲久久久久久久久久| 欧美中文在线字幕| 国产一区二区三区18| 日韩精品视频免费在线观看| 国产成人免费av电影| 日韩中文在线视频| 欧美性xxxx极品hd满灌| 欧美日本高清一区| 国产欧美精品久久久| 国产精品久久久久久久久免费| 清纯唯美亚洲综合| 精品国产依人香蕉在线精品| 91视频8mav| 亚洲一区国产精品| 亚洲精品自拍视频| 国产精品爽黄69| 国产精品日韩欧美| 国产91精品最新在线播放| 国产综合视频在线观看| 欧美视频一区二区三区…| 国产视频观看一区| 久久久久久免费精品| 97超级碰在线看视频免费在线看| 国产精品99久久99久久久二8| 国产久一一精品| 国产精品三级网站| 久国内精品在线| 久久久久女教师免费一区| 欧美日韩不卡合集视频|