Arrays中asList()方法源碼剖析

今天偶爾用到了Arrays中asList()方法,就看了下源碼;然後想把自己理解的意思分享下,如果哪裏寫錯了,希望大家糾正

// 數組轉集合
   @SafeVarargs
 public static <T> List<T> asList(T... a) {
        return new ArrayList<>(a);    // 1.創建一個ArrayList 此ArrayList是一個靜態內部類,並非是一個集合
 }

private static class ArrayList<E> extends AbstractList<E>
        implements RandomAccess, java.io.Serializable
    {
        private static final long serialVersionUID = -2764017481108945198L;
        private final E[] a;  // 2.定義一個常量數組命名爲 a(常量是不可改變的,所以如果賦值爲這個常量就不可以進行crud操作)

        ArrayList(E[] array) {  // 3.如果傳遞進來的數組是null 直接拋出異常
            if (array==null)
                throw new NullPointerException();
            a = array; // 4.否則把傳遞進來的數組賦值給定義的常量數組a
        }

        public int size() { // 5.數組長度
            return a.length;
        }

        public Object[] toArray() { // 6.克隆數組(返回原來的副本)
            return a.clone();
        }

        public <T> T[] toArray(T[] a) {// 7.方法重載,最終也是返回一個數組.裏面這個a是克隆後的
            int size = size(); // 8.這個size()是 5的size()
            if (a.length < size) 
                // 9.copyOf api是這麼解釋的:複製指定的數組,截取或用 null 填充(如有必要),以使副本具有指定的長度。
                // 這一塊有點不是很清楚,我是這樣理解的:因爲length的長度小於size;在size多出來的部分使用null去填充.(按理來說應該不會出現這種狀況,個人理解)
                return Arrays.copyOf(this.a, size,  
                                     (Class<? extends T[]>) a.getClass());
            System.arraycopy(this.a, 0, a, 0, size); // 10.從指定源數組中複製一個數組,複製從指定的位置開始,到目標數組的指定位置結束。
            if (a.length > size)
                a[size] = null;
            return a; // 11.複製完進行返回
        }

        public E get(int index) {
            return a[index];
        }

        public E set(int index, E element) {
            E oldValue = a[index];
            a[index] = element;
            return oldValue;
        }

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

        public boolean contains(Object o) {
            return indexOf(o) != -1;
        }
    }

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章