Arrays数组工具类中存在的坑!
以下是一个坑:
看到使用asList时候,可以返回一个集合,当然集合拥有CRUD的特性;
代码中使用 了add和remove时候均报错:Exception in thread "main" java.lang.UnsupportedOperationException
很奇怪的问题出现了,集合为什么不能add 和remove呢??
这段是asList的源码,好像没啥问题.
public static <T> List<T> asList(T... a) { return new ArrayList<>(a); }
---------
发现这个 ArrayList 并不是Util包下的ArrayList;其实是他的一个内部类,通过这个类,我们可以很明显看出,这个类中是没有add remove 方法的;
当我们编译时候是没有出现报错的,源码中定义了,运行时候会做检查:
public void add(int index, E element) {
throw new UnsupportedOperationException();
}
-------
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) { E[] a = this.a; 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; } @Override public boolean contains(Object o) { return indexOf(o) != -1; } @Override public Spliterator<E> spliterator() { return Spliterators.spliterator(a, Spliterator.ORDERED); } @Override public void forEach(Consumer<? super E> action) { Objects.requireNonNull(action); for (E e : a) { action.accept(e); } } @Override public void replaceAll(UnaryOperator<E> operator) { Objects.requireNonNull(operator); E[] a = this.a; for (int i = 0; i < a.length; i++) { a[i] = operator.apply(a[i]); } } @Override public void sort(Comparator<? super E> c) { Arrays.sort(a, c); } }
总结:
1.如果你的list是用来遍历的,那么没啥问题。你可以使用asList.
2.你的集合是用来改变的,还是老老实实new 吧;
梦想一定要有,万一实现了!