Java集合類的組織結(jié)構(gòu)和繼承、實(shí)現(xiàn)關(guān)系詳解
Collection繼承、實(shí)現(xiàn)關(guān)系如下(說明(I)表示接口, (C)表示Java類,<--表示繼承,<<——表示實(shí)現(xiàn)):
(I)Iterable
|<-- (I)Collection
|<-- (I)List
|<<—— (C)ArrayList
|<<—— (C)LinkedList
|<<—— (C)Vector
|<-- (I)Set
|<<—— (C)HashSet
|<-- (I)Queue [kju]
Map繼承、實(shí)現(xiàn)關(guān)系如下
Map
|<<—— (C)HashMap
|<<—— (C)HashTable
Iterable:
package java.lang; import java.util.Iterator; public interface Iterable<T> { Iterator<T> iterator(); }
Iterator:
package java.util; public interface Iterator<E> { boolean hasNext(); E next(); void remove(); }
Collection:
package java.util; public interface Collection<E> extends Iterable<E> { int size(); boolean isEmpty(); boolean contains(Object o); Iterator<E> iterator(); Object[] toArray(); <T> T[] toArray(T[] a); boolean add(E e); boolean remove(Object o); boolean containsAll(Collection<?> c); boolean addAll(Collection<? extends E> c); boolean removeAll(Collection<?> c); boolean retainAll(Collection<?> c); void clear(); boolean equals(Object o); int hashCode(); }
Map:
package java.util; public interface Map<K,V> { int size(); boolean isEmpty(); boolean containsKey(Object key); boolean containsValue(Object value); V get(Object key); V put(K key, V value); V remove(Object key); void putAll(Map<? extends K, ? extends V> m); void clear(); Set<K> keySet(); Collection<V> values(); Set<Map.Entry<K, V>> entrySet(); interface Entry<K,V> { K getKey(); V getValue(); V setValue(V value); boolean equals(Object o); int hashCode(); } boolean equals(Object o); int hashCode(); }
1、Collection和Map的區(qū)別
Collection和Map最大的區(qū)別就是Collection存儲(chǔ)的是一組對象;Map是以“鍵值對”的形式對對象進(jìn)行的管理。
2、Iterable和Iterator
Iterator是迭代器,Iterable是接口。很多類,像List、Set、HashMap不直接實(shí)現(xiàn)迭代器接口Iterator,而是去實(shí)現(xiàn)Iterable接口,是因?yàn)椋?/p>
Iterator的方法next()和hasNext()是依賴當(dāng)前迭代位置的,直接實(shí)現(xiàn)Iterator,集合在不同方法間傳遞時(shí),會(huì)包含一個(gè)當(dāng)前迭代位置的指針;
而Iterable每次調(diào)用都會(huì)返回一個(gè)從頭開始計(jì)數(shù)的迭代器。
3、Collection和Collections的區(qū)別
Collection是一個(gè)集合接口。它提供了對集合對象進(jìn)行進(jìn)本操作的通用接口方法。
Collections是一個(gè)工具類。內(nèi)有多個(gè)對集合對象進(jìn)行操作的靜態(tài)方法,不能實(shí)例化。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Maven依賴中scope的runtime和provied的區(qū)別及說明
這篇文章主要介紹了Maven依賴中scope的runtime和provied的區(qū)別及說明,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-11-11關(guān)于Java變量的聲明、內(nèi)存分配及初始化詳解
下面小編就為大家?guī)硪黄P(guān)于Java變量的聲明、內(nèi)存分配及初始化詳解。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-03-03Java中的StampedLock實(shí)現(xiàn)原理詳解
這篇文章主要介紹了Java中的StampedLock實(shí)現(xiàn)原理詳解,ReentrantReadWriteLock采用悲觀讀,第一個(gè)讀線程拿到鎖后,第二個(gè)/第三個(gè)讀線程可以拿到鎖,特別是在讀線程很多,寫線程很少時(shí),需要的朋友可以參考下2024-01-01如何解決使用restTemplate進(jìn)行feign調(diào)用new HttpEntity<>報(bào)錯(cuò)問題
這篇文章主要介紹了如何解決使用restTemplate進(jìn)行feign調(diào)用new HttpEntity<>報(bào)錯(cuò)問題,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-06-06Java使用list集合remove需要注意的事項(xiàng)(使用示例)
List集合的一個(gè)特點(diǎn)是它其中的元素是有序的,也就是說元素的下標(biāo)是根據(jù)插入的順序來的,在刪除頭部或者中間的一個(gè)元素后,后面的元素下標(biāo)會(huì)往前移動(dòng),本文給大家介紹Java使用list集合remove需要注意的事項(xiàng),感興趣的朋友一起看看吧2022-01-01