溫馨提示×

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

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Java list與set中contains()方法效率的實(shí)例講解

發(fā)布時(shí)間:2021-08-31 12:51:32 來(lái)源:億速云 閱讀:354 作者:chen 欄目:開發(fā)技術(shù)

這篇文章主要講解了“Java list與set中contains()方法效率的實(shí)例講解”,文中的講解內(nèi)容簡(jiǎn)單清晰,易于學(xué)習(xí)與理解,下面請(qǐng)大家跟著小編的思路慢慢深入,一起來(lái)研究和學(xué)習(xí)“Java list與set中contains()方法效率的實(shí)例講解”吧!

  • list.contains(o) :遍歷集合所有元素,用每個(gè)元素和傳入的元素進(jìn)行 equals 比較,如果集合元素有 n 個(gè),則會(huì)比較 n 次,所以時(shí)間復(fù)雜度為 O(n) 。方法源碼如下:

// ArrayList 中的方法
public boolean contains(Object o) {
      return indexOf(o) >= 0;
}
 
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;
}
  • set.contains(o) :set 集合是用 HashMap 實(shí)現(xiàn)的,其中 add 方法將每個(gè)元素當(dāng)做鍵,以一個(gè)object 對(duì)象作為值放在 HashMap 中,而 set 的 contains 方法調(diào)用了 HashMap 的 containKey 方法,直接獲取傳入元素的鍵值對(duì)信息做判斷,所以 contains 的方法復(fù)雜度為 O(1) 。方法源碼如下:

// HashSet 中的方法
public boolean add(E e) {
	 // PRESENT 是一個(gè)object對(duì)象
   return map.put(e, PRESENT)==null;
}
public boolean contains(Object o) {
      return map.containsKey(o);
}


//  HashMap 中的方法
public boolean containsKey(Object key) {
  	  return getNode(hash(key), key) != null;
}

final Node<K,V> getNode(int hash, Object key) {
	  Node<K,V>[] tab; Node<K,V> first, e; int n; K k;
	    if ((tab = table) != null && (n = tab.length) > 0 &&
	        (first = tab[(n - 1) & hash]) != null) {
	        if (first.hash == hash && // always check first node
	            ((k = first.key) == key || (key != null && key.equals(k))))
	            return first;
	        if ((e = first.next) != null) {
	            if (first instanceof TreeNode)
	                return ((TreeNode<K,V>)first).getTreeNode(hash, key);
	            do {
	                if (e.hash == hash &&
	                    ((k = e.key) == key || (key != null && key.equals(k))))
	                    return e;
	            } while ((e = e.next) != null);
	        }
	    }
	    return null;
}
//  getNode 方法同樣也被hashMap中的get方法所調(diào)用
public V get(Object key) {
        Node<K,V> e;
        return (e = getNode(hash(key), key)) == null ? null : e.value;
}
  • 在進(jìn)行contians判斷時(shí),全部用Set集合的contains方法,避免踩坑

感謝各位的閱讀,以上就是“Java list與set中contains()方法效率的實(shí)例講解”的內(nèi)容了,經(jīng)過(guò)本文的學(xué)習(xí)后,相信大家對(duì)Java list與set中contains()方法效率的實(shí)例講解這一問(wèn)題有了更深刻的體會(huì),具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是億速云,小編將為大家推送更多相關(guān)知識(shí)點(diǎn)的文章,歡迎關(guān)注!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI