当前位置: 代码迷 >> J2SE >> arrays解决思路
  详细解决方案

arrays解决思路

热度:211   发布时间:2016-04-23 20:15:06.0
arrays
 String[] arr = new String[] {"1", "2"};
    List<String> list = Arrays.asList(arr);
         
    for(int i=0;i<list.size();i++){
        System.out.println(list.get(i));       
    }
list.add("t");
list.add("p");
为什么add方法报错?
------解决思路----------------------
这个问题需要注意:

这里的ArrayList不是java.util.ArrayList,而是Arrays类的一个内部类(可以看asList方法的源代码);

虽然也可以用List访问,不过不能对其进行修改,即只读;

所以对Arrays.asList出来的List,对其做add、remove操作都会抛出UnsupportedOperationException异常;

其实java.util.Arrays.ArrayList其实只是对数组做了一个装饰,目的只是提供了可以像访问List那样来访问数组而已,本质上其实还是一个数组;

最好看一下这个Arrays类的源代码,里面写的很详细,也很清楚;


------解决思路----------------------
源码:
    
public static <T> List<T> asList(T... a) {
        return new ArrayList<>(a);
    }



private static class ArrayList<E> extends AbstractList<E>
        implements RandomAccess, java.io.Serializable
    {
        private static final long serialVersionUID = -2764017481108945198L;
        private final E[] a;

        ArrayList(E[] array) {
            a = Objects.requireNonNull(array);
        }

        @Override
        public int size() {
            return a.length;
        }

        @Override
        public Object[] toArray() {
            return a.clone();
        }

        @Override
        @SuppressWarnings("unchecked")
        public <T> T[] toArray(T[] a) {
            int size = size();
            if (a.length < size)
                return Arrays.copyOf(this.a, size,
                                     (Class<? extends T[]>) a.getClass());
            System.arraycopy(this.a, 0, a, 0, size);
            if (a.length > size)
                a[size] = null;
            return a;
        }

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

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

        @Override
        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]))
  相关解决方案