JavaでListをリテラルに記述して生成する方法が基本的にないので、
文字列List等を作る際には基本的にArrays#asList
を利用することが多いです。
ただし、Arrays#asList
によってに生成されるクラスはArrayList
という名前ですが、
いわゆるjava.util.ArrayList
とは別物であるということを知っておかなければなりません。
サンプルコードを実行して確認してみます。
■サンプルコード
import java.util.ArrayList; import java.util.Arrays; import java.util.List; List<String> list1 = Arrays.asList("a", "b", "c"); System.out.println("## Arrays#asList"); System.out.println("class: " + list1.getClass()); // list1.add("d"); -> throw java.lang.UnsupportedOperationException // list1.remove(0); -> throw java.lang.UnsupportedOperationException System.out.println("--------------------"); List<String> list2 = new ArrayList<>(); list2.add("a"); list2.add("b"); list2.add("c"); System.out.println("## ArrayList"); System.out.println("class: " + list2.getClass());
■実行結果
## Arrays.asList class: class java.util.Arrays$ArrayList -------------------- ## ArrayList class: class java.util.ArrayList
実行結果からArrays#asList
によって生成されるオブジェクトはjava.util.Arrays$ArrayList
というクラスであることが分かります
java.util.Arrays$ArrayList の実装内容
かなり省略していますがjava.util.Arrays$ArrayList
は以下のような実装になっています。
addやremove等のメソッドはAbstractListから継承してオーバーライドされていないというのがポイントとなります。
(そのためUnsupportedOperationException
がスローされる状態になっています)
public class Arrays { 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); } } } }