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;
        }
    }

 

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