集合

Collection

The root interface in the collection hierarchy. A collection represents a group of objects, known as its <i>elements</i>.
一些集合允許元素重復,一些則不然.一些集合是有序的,一些是無序的.JDK沒有提供該接口的直接實現,所有的實現都是基于Collection的子接口進行的實現,比如Set,List等等.

Collection默認提供兩個標準的構造函數:

1.沒有參數的構造函數,創建一個空的集合類
2.有一個類型與基類(Collection或Map)相同的構造函數,創建一個與給定參數具有相同元素的新集合類
  • 怎么來講,Collection就像一個封裝了一個微型的數據庫,也可以稱之為一個容器,對外提供了增刪改查的接口,同時,為我們封裝好了這個容器應該具有的一些其他操作,比如獲取這個容器的大小.容器是否為空等等一些所有容器類東西的通用操作.
  • 這些容器不僅限于一下:Set,List,Map,SortedSet,SortedMap,HashSet,TreeSet,ArrayList,LinkedList,Vector,Collections, Arrays, AbstractCollection.上述的容器不一定實現了Collection接口,但是他們都會很好的提供自身與Collection轉化的方法,一般都會包含Collection,比如AbstractHashMap如下圖.
AbstractHashMap
  • 設計理念:

Collection提供了一套小而美的API,API接口需要對程序員友好,增加新功能時,能讓程序員快速上手.
Collection與Map接口不會區分該集合是否可變(mutability),是否可更改(modifiability),是否可改變大小(resizability)這些細微的差別.相反,一些操作是可選的,在實現時拋出UnsupportedOperationException即可表示集合不支持該操作。集合的實現者必須在文檔中聲明那些操作是不支持的。

  • 類圖:

那么,一個一個來:
Set

Iterator


package java.util;

/**
集合之上的Iterator,是所有集合實現的一個接口
設計目的:抽象遍歷集合的邏輯,避免向用戶暴露集合內部過多的結構與實現
 */
public interface Iterator<E> {
    /**當前遍歷器有下一個元素是,返回true;以免拋出異常
*/
    boolean hasNext();

    /**
     返回下一個元素;如果沒有,則拋出NoSuchElementException異常
     */
    E next();

    /**
    移除當前遍歷器中的最后一個元素,每次使用next()方法,只能使用一次該方法。
當前迭代器有對集合修改的動作時,該集合的遍歷器的行為是不確定的。這句話有些抽象,
可以下面的example 1。
同樣,該方法用了java8的特性,default-虛擬擴展方法
使用目的:在該接口中進行默認實現,提高接口的擴展性,避免在接口擴展的時候,破壞原有的實現
     */
    default void remove();
}

example 1

Iterable

/*實現該接口的object可以使用“for-each loop”表達式*/
public interface Iterable<T> {
    /*返回一個基于泛型T類型的Iterator*/
    Iterator<T> iterator();

    /**
    對每一個元素執行給出的動作。 
     * @implSpec
     * <p>The default implementation behaves as if:
     * <pre>{@code
     *     for (T t : this)
     *         action.accept(t);
     * }</pre>
     *
     * @param action The action to be performed for each element
     * @throws NullPointerException if the specified action is null
     * @since 1.8
     */
    default void forEach(Consumer<? super T> action) {
        Objects.requireNonNull(action);
        for (T t : this) {
            action.accept(t);
        }
    }

    /**
     * Creates a {@link Spliterator} over the elements described by this
     * {@code Iterable}.
     *
     * @implSpec
     * The default implementation creates an
     * <em><a href="Spliterator.html#binding">early-binding</a></em>
     * spliterator from the iterable's {@code Iterator}.  The spliterator
     * inherits the <em>fail-fast</em> properties of the iterable's iterator.
     *
     * @implNote
     * The default implementation should usually be overridden.  The
     * spliterator returned by the default implementation has poor splitting
     * capabilities, is unsized, and does not report any spliterator
     * characteristics. Implementing classes can nearly always provide a
     * better implementation.
     *
     * @return a {@code Spliterator} over the elements described by this
     * {@code Iterable}.
     * @since 1.8
     */
    default Spliterator<T> spliterator() {
        return Spliterators.spliteratorUnknownSize(iterator(), 0);
    }
}

ListIterator

package java.util;

/**
Iterator接口的擴展,為list實現的雙向遍歷,并且能獲取到當前遍歷的位置,
 */
public interface ListIterator<E> extends Iterator<E> {
    boolean hasNext();
    E next();
    /**
是否有上一個參數。詳細參考一下鏈接: http://sungang-1120.iteye.com/blog/1747384
     */
    boolean hasPrevious();
   /*返回上一個元素*/
    E previous();
    /**返回下一個元素的坐標,直到返回list.size
     */
    int nextIndex()
    /**
    返回上一個坐標,直到返回-1
     */
    int previousIndex();
    /**
     移除剛剛指向的元素(next()或者previous()操作之后的指向的那個元素)
     */
    void remove()
    /**
    元素插入到list末尾
     */
    void set(E e);
    /**
    插入元素到列表頭部,詳細參考:http://www.cnblogs.com/baiqiantao/p/5449434.html
     */
    void add(E e);
}

Vector

構造方法:
 public Vector(int initialCapacity, int capacityIncrement) {
        super();
        if (initialCapacity < 0)
            throw new IllegalArgumentException("Illegal Capacity: "+
                                               initialCapacity);
        this.elementData = new Object[initialCapacity];
        this.capacityIncrement = capacityIncrement;
    }
    public Vector(int initialCapacity) {
        this(initialCapacity, 0);
    }
    public Vector() {
        this(10);
    }
public Vector(Collection<? extends E> c) {
        elementData = c.toArray();
        elementCount = elementData.length;
        // c.toArray might (incorrectly) not return Object[] (see 6260652)
        if (elementData.getClass() != Object[].class)
            elementData = Arrays.copyOf(elementData, elementCount, Object[].class);
    }
/×將vetcor中的元素拷貝到anArray數組中,同步方法×/
    public synchronized void copyInto(Object[] anArray) {
        System.arraycopy(elementData, 0, anArray, 0, elementCount);
    }
/×將當前數組的容量改為當前數組數據數量的大小×/`
public synchronized void trimToSize() {
        modCount++;
        int oldCapacity = elementData.length;
        if (elementCount < oldCapacity) {
            elementData = Arrays.copyOf(elementData, elementCount);
        }
    }

AbstractList

/*在對一個集合對象進行跌代操作的同時,并不限制對集合對象的元素進行操 作,這些操作包括一些可能引起
跌代錯誤的add()或remove()等危險操作。在AbstractList中,使用了一個簡單的機制來規避這些風險。 這就是
modCount(存在于AbstractList)和expectedModCount(存在于該類實現的接口iterator中)的作用所在。詳
細參考:http://liuzhaomin.iteye.com/blog/1038289*/
protected transient int modCount = 0;
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 227,702評論 6 531
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 98,143評論 3 415
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 175,553評論 0 373
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 62,620評論 1 307
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,416評論 6 405
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 54,940評論 1 321
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,024評論 3 440
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,170評論 0 287
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 48,709評論 1 333
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 40,597評論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 42,784評論 1 369
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,291評論 5 357
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,029評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,407評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,663評論 1 280
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,403評論 3 390
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 47,746評論 2 370

推薦閱讀更多精彩內容

  • Collection ├List │├LinkedList │├ArrayList │└Vector │└Stac...
    AndyZX閱讀 884評論 0 1
  • 集合類簡介 為什么出現集合類?面向對象語言對事物的體現都是以對象的形式,所以為了方便對多個對象的操作,就要對對象進...
    阿敏其人閱讀 1,432評論 0 7
  • 概述 Java集合框架由Java類庫的一系列接口、抽象類以及具體實現類組成。我們這里所說的集合就是把一組對象組織到...
    absfree閱讀 1,261評論 0 10
  • 1.Java集合框架是什么?說出一些集合框架的優點? 每種編程語言中都有集合,最初的Java版本包含幾種集合類:V...
    joshul閱讀 373評論 0 2
  • 1.Java集合框架是什么?說出一些集合框架的優點?每種編程語言中都有集合,最初的Java版本包含幾種集合類:Ve...
    yjaal閱讀 1,184評論 1 10