Forma il concetto di ereditarietà. Se un metodo perticolare non è disponibile nella classe corrente, cercherà quel metodo in superclassi. Se disponibile, viene eseguito.
Esegue il metodo di AbstractList<E>
classe add()
che genera UnsupportedOperationException
.
Quando si esegue la conversione da una matrice a una raccolta Obejct. ovvero, basato sull'array basato sull'API basata sulla raccolta, fornirà un oggetto raccolta di dimensioni fisse, poiché il comportamento dell'array è di dimensioni fisse.
java.util.Arrays.asList (T ... a)
Souce campioni per conformazione.
public class Arrays {
public static <T> List<T> asList(T... a) {
return new java.util.Arrays.ArrayList.ArrayList<>(a); // Arrays Inner Class ArrayList
}
//...
private static class ArrayList<E> extends AbstractList<E> implements RandomAccess, java.io.Serializable {
//...
}
}
public abstract class AbstractList<E> extends AbstractCollection<E> implements List<E> {
public void add(int index, E element) {
throw new UnsupportedOperationException();
}
public E set(int index, E element) {
throw new UnsupportedOperationException();
}
public E remove(int index) {
throw new UnsupportedOperationException();
}
public Iterator<E> iterator() {
return new Itr();
}
private class Itr implements Iterator<E> {
//...
}
public ListIterator<E> listIterator() {
return listIterator(0);
}
private class ListItr extends Itr implements ListIterator<E> {
//...
}
}
Da quanto sopra puoi osservare che la java.util.Arrays.ArrayList
classe no @Override add(index, element), set(index, element), remove(index)
. Quindi, dall'ereditarietà esegue la funzione di super AbstractList<E>
classe add()
che genera UnsupportedOperationException
.
Come AbstractList<E>
è una classe astratta che fornisce l'implementazione a iterator() and listIterator()
. In modo che possiamo iterare sull'oggetto elenco.
List<String> list_of_Arrays = Arrays.asList(new String[] { "a", "b" ,"c"});
try {
list_of_Arrays.add("Yashwanth.M");
} catch(java.lang.UnsupportedOperationException e) {
System.out.println("List Interface executes AbstractList add() fucntion which throws UnsupportedOperationException.");
}
System.out.println("Arrays → List : " + list_of_Arrays);
Iterator<String> iterator = list_of_Arrays.iterator();
while (iterator.hasNext()) System.out.println("Iteration : " + iterator.next() );
ListIterator<String> listIterator = list_of_Arrays.listIterator();
while (listIterator.hasNext()) System.out.println("Forward iteration : " + listIterator.next() );
while(listIterator.hasPrevious()) System.out.println("Backward iteration : " + listIterator.previous());
Puoi persino creare un array a dimensione fissa dalla classe Collezioni Collections.unmodifiableList(list);
Fonte campione:
public class Collections {
public static <T> List<T> unmodifiableList(List<? extends T> list) {
return (list instanceof RandomAccess ?
new UnmodifiableRandomAccessList<>(list) :
new UnmodifiableList<>(list));
}
}
A Collection
- a volte chiamato contenitore - è semplicemente un oggetto che raggruppa più elementi in una singola unità. Le raccolte vengono utilizzate per archiviare, recuperare, manipolare e comunicare dati aggregati.
@Guarda anche