In diesem Artikel werden hauptsächlich relevante Informationen zu Anwendungsbeispielen für Java-Listen vorgestellt. Freunde, die sie benötigen, können sich auf
Detaillierte Anwendungsbeispiele für Java-Listen beziehen
Java kann Das Prinzip von Das variable Array dient dazu, kontinuierlich neue Arrays zu erstellen und das ursprüngliche Array zum neuen Array hinzuzufügen. Die Verwendung von Java List wird im Folgenden ausführlich erläutert.
Liste: Die Elemente sind in der richtigen Reihenfolge (Sie können sie beim Speichern herausnehmen, die Reihenfolge wird nicht durcheinander gebracht), und die Elemente können wiederholt werden (es gibt eine 3 auf Index 1 und eine 3 auf Index 2 Es kann auch 3 geben), da das Sammelsystem einen Index
ArrayList hat: Die zugrunde liegende Datenstruktur verwendet eine Array-Struktur (die Array-Länge ist variabel). und kann um 50 % erweitert werden (Das Merkmal ist, dass die Abfrage schnell ist, das Hinzufügen und Löschen jedoch langsam ist) Der Thread ist nicht synchronisiert
LinkedList: Die zugrunde liegende Datenstruktur ist eine verknüpfte Listenstruktur (das Merkmal ist, dass die Abfrage langsam ist und das Hinzufügen und Löschen schnell erfolgt)
Vektor: Die unterste Ebene ist die Thread-Synchronisation der Array-Datenstruktur (die Array-Länge beträgt variabel und 100 % erweitert) (sowohl Abfrage als auch Hinzufügen und Löschen sind sehr langsam, ersetzt durch ArrayList)
Liste: Einzigartige Methoden, alle Methoden, die Eckmarkierungen bedienen können, sind einzigartig zum System
boolean add(int index, E element) boolean addAll(index,Collection)
public static void List_add(){ ArrayList a1 = new ArrayList(); a1.add("java"); a1.add("php");//List集合中的元素可以重复 a1.add(".net"); System.out.println("原集合:"+a1); a1.add(1, "Flash"); a1.add(0, "ps"); System.out.println(a1); ArrayList a2 = new ArrayList(); a2.add("javascript"); a2.add("3dMax"); a2.add("IBM"); a1.addAll(0, a2); System.out.println(a1); }
Element an der angegebenen Position löschen
boolean remove(int index)
public static void List_remove(){ ArrayList a1 = new ArrayList(); a1.add("javascript"); a1.add("php"); a1.add("flash"); System.out.println("原集合:"+a1); a1.remove(0); System.out.println(a1); }
Ändern Sie das Element am angegebenen Indexsatz (int-Index, E-Element). Gibt das geänderte Element zurück
public static void List_set() { ArrayList a1 = new ArrayList(); a1.add("javascript"); a1.add("php"); a1.add(".net"); System.out.println("原集合:"+a1); a1.set(1, "falsh"); System.out.println(a1); }
Prüfen
get(int index) // 返回列表中指定位置的元素 subList(int fromIndex, int toIndex) // 返回列表中指定的 fromIndex(包括 )和 toIndex(不包括)之间的部分元素。
public static void List_get() { ArrayList a1 = new ArrayList(); a1.add("java"); a1.add("php"); a1.add("flash"); System.out.println(a1.get(0));//获取指定角标的元素,有了该方法就可以遍历该集合中的所有元素 System.out.println(a1.subList(1, 3));//获取集合中某一部分的元素,包含头不包含尾 }
Iterator, der nur für die List-Sammlung gilt: ListIterator (ist ein Sub -Schnittstelle des Iterators)
Hinweis:
Beim Iterieren ist dies nicht der Fall. Die Elemente in der Sammlung können über die Methoden des Sammlungsobjekts manipuliert werden, da eine ConcurrentModificationException ( Daher können Sie bei Verwendung eines Iterators nur die Iterator-Methode zum Erstellen von Elementen verwenden. Da die Iterator-Methode begrenzt ist, können Sie die Elemente nur dann beurteilen, wenn Sie andere Vorgänge wünschen B. zum Hinzufügen, Ändern usw., müssen Sie die Unterschnittstelle ListIterator verwenden. Diese Schnittstelle kann nur über die listIterator-Methode der List-Sammlung
public class ListIteratorDemo { public static void main(String[] args) { ArrayList a1 = new ArrayList(); a1.add("java01"); a1.add("java02"); a1.add("java03"); a1.add("java04"); System.out.println("原集合是:"+a1); /*在迭代过程中准备添加或者删除元素 Iterator it = al.iterator(); while (it.hasNext()){ Object obj = it.next(); if (obj.equals("java02")) //al.add("java008");//会出现并发异常,因为迭代器正在操作集合,不能再用集合的方法操作集合了 it.remove();//将java02的引用从集合中删除了 System.out.println("obj:"+obj); } */ //只有List的listIterator有增,删,改,查这些功能,因为只有List有索引 ListIterator li = a1.listIterator(); while (li.hasNext()){ if(li.next().equals("java02")) //li.add("java009"); li.set("java006"); } } }
public class VectorDemo { public static void main(String[] args) { Vector v = new Vector(); v.add("java01"); v.add("java02"); v.add("java03"); v.add("java04"); for(Enumeration en = v.elements();en.hasMoreElements();){ System.out.println(en.nextElement()); } } }
Spezielle Methoden:
addFirst(); Elemente am Kopf hinzufügenaddLast(); Elemente am Ende hinzufügen getFirst(); getLast();Elemente abrufen, aber nicht löschen. Wenn keine Elemente in der Sammlung vorhanden sind, tritt NoSuchElementException aufremoveFirst(); removeLast();Das Element abrufen, aber löschen. Wenn keine Elemente in der Sammlung vorhanden sind, tritt eine NoSuchElementException auf. In JDK1.6 werden alternative Methoden offerFirst(); offerLast();peekFirst(); () ; Holen Sie sich das Element, aber das Element wird nicht gelöscht. Wenn die Sammlung keine Elemente enthält, wird null zurückgegebenpollFirst(); pollLast(); Das Element wird abgerufen, aber das Element wird gelöscht. Wenn die Sammlung keine Elemente enthält, wird nullDas obige ist der detaillierte Inhalt vonDetaillierte Erläuterung von Beispielen für die Verwendung von Listen in Java. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!