Frage Performance bei Linked List und Array List

8u3631984

Bekanntes Mitglied
Hallo zusamen :
Ich habe auf Youtube folgendes Video zum Thema LinkedList und ArrayList mir angesehen :

Ich wollte die Performance in einem kleinem Java Programm messen :
Dazu will ich in eine ArrayList und LinkedList jeweils die gleiche Anzahl von Elementen einfügen und wieder löschen. Nach meinem Verständnis sollte die Linked List deutlich schneller sein.

Hier ist mein Programm :
Java:
    public static int numberOfElements = 10000000;
    public static int numberOfActions = 100;

    /**
     * @param args
     */
    public static void main(String[] args) { 
        System.out.println("erzeuge ein ArrayList mit " + numberOfElements + " Elementen");
        ArrayList<Integer> myArrayList = new ArrayList<>();
        listAction(myArrayList);

        System.out.println("--------------------------------");

        System.out.println("erzeuge ein LinkedList mit " + numberOfElements + " Elementen");
        LinkedList<Integer> myLinkedList = new LinkedList<>();
        listAction(myLinkedList);
    }

    public static long actionAddElements(List<Integer> myList){
        var startTimeStamp = System.currentTimeMillis();
        for (int i = 0; i < numberOfElements; i++){
            myList.add(i);
        }
        var endTimeStamp = System.currentTimeMillis();
        var duration = endTimeStamp - startTimeStamp;

        return duration;
    }

    public static long actionRemoveElemnts(List<Integer> myList){
        var startTimeStamp = System.currentTimeMillis();
        for (int i = numberOfElements - 1 ; i >= 0 ; i--){
            myList.remove(i);
        }
        var endTimeStamp = System.currentTimeMillis();
        var duration = endTimeStamp - startTimeStamp;

        return duration;
    }

    public static void listAction(List<Integer> myList){
        long durationAdd = 0;
        long durationRemove = 0;

        for (int i = 0; i < numberOfActions; i++){
            durationAdd += actionAddElements(myList);
            durationRemove += actionRemoveElemnts(myList);
        }

        System.out.println("dauer einfügen " + durationAdd / numberOfActions);
        System.out.println("dauer löschen " + durationRemove / numberOfActions);
    }

Kurz zur Erklärung : In meinen ersten Versuchen war die ArrayList immer schneller. Dher habe ich das Programm umgebaut. Nun werden die Aktionen 100x ausgeführt und der Mittelwert der Zeit zum Hinzufügen und Löschen gebildet :

hier die ausgabe :
Code:
erzeuge ein ArrayList mit 10000000 Elementen
dauer einfügen 51 ms
dauer löschen 11 ms
--------------------------------
erzeuge ein LinkedList mit 10000000 Elementen
dauer einfügen 848 ms
dauer löschen 104 ms

Hat jemand eine erklärung dafür
 

Robert Zenz

Top Contributor
Ich habe mir jetzt das Video nicht angesehen, aber eine ArrayList zu schlagen wenn sie nicht das Array erweitern muss wird sehr schwierig werden. Im Groszen und Ganzen ist ein Hinzufuegen in der ArrayList naemlich:

Java:
public void add(LIST_TYPE item) {
    int newCount = count + 1;

    if (newCount >= array.length) {
        array = grow(count * 2);
    }
 
    array[count] = item;

    count = newCount;
}

Also wirklich, wirklich billig wenn nicht das Array vergroeszert werden muss. Dagegen muss in einer LinkedList ein paar Sachen gemacht werden wenn sich das letzte Element aendert.

Hinzu kommt noch dass dein Test-Aufbau ein paar Probleme, zu naechst naemlich Auto-Boxing und dann wahrscheinlich ein Speicherproblem.

Waehrend die Operationen auf der ArrayList sehr billig moeglich sind, insbesondere in dem Moment wo das interne Array einmal grosz genug erweitert worden ist, ist es wirklich nur ein "wie schnell kann ich Elemente in ein Array setzen". Die LinkedList muss mindestens ein neues Objekt je Hinzufuegen erzeugen, erzeugt also 1.000.000.000 Objekte welche auch wieder verworfen werden muessen. Dein Test ist so also nicht aussagekraeftig weil dir irgendwann die Garbage Collection einen Strich durch die Rechnung machen wird. Hinzu kommt dann noch das Auto-Boxing welches ebenfalls Objekte erzeugt welche wieder verworfen werden. Alles nicht ideal, dann fuehrst du beide Tests noch in der selben JVM aus, also der LinkedList-Test "erbt" schonmal einen Speicher der mit Dingen belegt ist.

Im ersten Schritt wuerde ich die Element durch eine fixe Object Instanz ersetzen.

Java:
private static final Object ELEMENT_INSTANCE = new Object();

// ...

for (int i = 0; i < numberOfElements; i++){
    myList.add(ELEMENT_INSTANCE);
}

Damit nimmst du hier schonmal unnoetige Objekt-Instanzen raus.

Du kannst dir auch jeder Zeit den Quellcode von ArrayList und LinkedList ansehen, dann kannst du das selbst vermutlich besser verstehen.
 

8u3631984

Bekanntes Mitglied
Vielen dank für die erklärung.

Ich habe nun mal folgende Änderunge vorgenommen :
Ein kleines eigenes Objekt verwendet und ab einer Größe > 2 immer an der zweiten Position einfügen. Nun bekomme ich folgende Ergebnisse :
erzeuge ein ArrayList mit 500000 Elementen
dauer einfügen 13522 ms
dauer löschen 1 ms
--------------------------------
erzeuge ein LinkedList mit 500000 Elementen
dauer einfügen 10 ms
dauer löschen 3 ms

Nun ist der UNterschied deutlicher !!!
 

LimDul

Top Contributor
Der Thread ist übrigens ein perfektes Beispiel, warum Performance-Messungen so schwierig sind (Wir misst misst Mist).

Es ist immer die Frage - was messe ich eigentlich? Messe ich den Code, den ich messen will? Oder messe ich was anderes? Was ist eigentlich mein Szenario? Was sind eigentlich die Rahmenbedingungen.

Wie man hier sieht, spielt so viel eine Rolle:
  • Werden die Elemente neu erzeugt oder nicht?
  • Garbage Collection
  • Wo werden die Elemente eingefügt
  • Wie werden die Elemente gelöscht

Dann nehmen wir noch hinzu:
  • Speichermanagement der JVM
  • JIT-Compiler
  • Optimierungen der CPU

Am Ende am zwar zwei Zeiten die man vergleichen kann - aber kann man sie auch übertragen auf was anderes? Spätestens da wird es schwer.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
S Performance Frage: Objekt oder static? Allgemeine Java-Themen 33
M Runtime.exec() - Performance / Frage zu Threads Allgemeine Java-Themen 5
KonradN Mal eine Frage zu Binary Serialization Allgemeine Java-Themen 15
8u3631984 Frage zu Java Streams min / max Allgemeine Java-Themen 17
H Frage regex greater than less than Allgemeine Java-Themen 7
berserkerdq2 Frage zu IntelliJ und JavaFX Allgemeine Java-Themen 1
W Timer Konzept-Frage Allgemeine Java-Themen 16
T Eine Frage des Designs Allgemeine Java-Themen 2
C Frage zu eigenem TableCellRenderer Allgemeine Java-Themen 11
C Programmvorstellung & Frage zum Thema Geschäftsform Allgemeine Java-Themen 51
J Frage zu System.getproperties. Allgemeine Java-Themen 60
molat100 wie kann man die Frage beantworten Allgemeine Java-Themen 1
pkm Frage zur Präzision von Calendar.WEEK_OF_YEAR Allgemeine Java-Themen 12
J Eine Frage zu den Threads und Task Allgemeine Java-Themen 1
pkm Frage nach eventuellem syntaktischen Zucker bei der Konkatenation von ArrayLists Allgemeine Java-Themen 4
M Frage-Antwortspiel wie Wer wird Millionär Allgemeine Java-Themen 1
F Frage zu System.in Allgemeine Java-Themen 3
marcooooo Frage zum Beispiel im Anhang Allgemeine Java-Themen 16
T Meine Frage lautet wie ich 2 CSV Dateien miteinander in Java verbinde und Spalten die zueinander gehören durch den gleichen Key zusammen ausgebe? Allgemeine Java-Themen 5
S Noch eine Design-Frage zu Setter Allgemeine Java-Themen 6
B For-Loop Frage Allgemeine Java-Themen 21
L Java frage Allgemeine Java-Themen 3
bueseb84 Frage zu Mock und UpperBound Allgemeine Java-Themen 2
M Frage zum Konstruktor Allgemeine Java-Themen 2
W Best Practice Frage zur Umsetzung MVC Allgemeine Java-Themen 9
P String-Verschlüsselung - Frage zur Sicherheit Allgemeine Java-Themen 21
B Frage zu Unit-Tests Allgemeine Java-Themen 6
T Allgemeine Frage: GUI für 3D-Visualisierung Allgemeine Java-Themen 5
R Allgemeine Frage zu RMI bei MVC Allgemeine Java-Themen 2
O Frage zum Runtimeverhalten von Java ... Allgemeine Java-Themen 2
H Rundreise frage (Algorithmus) Allgemeine Java-Themen 18
B Generelle Frage bei einer Webanwendung / Reduzierung von DB Abfragen Allgemeine Java-Themen 1
D Frage zu Vererbung Allgemeine Java-Themen 5
J Frage zu regulärem Ausdruck Allgemeine Java-Themen 2
M Allgemeine Frage: Wie lernt man Java / Programmieren von Grund auf? Allgemeine Java-Themen 7
rentasad Design-Frage - Interfaces, Klassen, statische Methoden Allgemeine Java-Themen 3
S Frage zur JLS Allgemeine Java-Themen 0
J Verständnis Frage zur Instanz, Objekte, Instanzierung, Referenz Allgemeine Java-Themen 14
A Methoden Allgemeine Java Frage Allgemeine Java-Themen 3
E String Frage Allgemeine Java-Themen 9
I bin neu bei GitHub, Frage zur Sicherheit Allgemeine Java-Themen 14
C J2V8 NodeJs Java Bride Problem und Frage!?!? Allgemeine Java-Themen 1
C KeyListener Frage Allgemeine Java-Themen 3
T Frage zu UML in Java programmieren Allgemeine Java-Themen 1
R Konstanten initialisieren - FRAGE Allgemeine Java-Themen 3
MTJ004 FTP Frage zu FTP Speicherung Java-Android-FTP Allgemeine Java-Themen 5
J Frage zum Entwurf / json-Datenmodell Allgemeine Java-Themen 8
A Frage zu meinem Code Allgemeine Java-Themen 2
RalleYTN Classpath Nur ne kleine Frage zur MANIFEST.MF Allgemeine Java-Themen 4
T Frage zu Access Modifiers Allgemeine Java-Themen 6
W Input/Output Frage zu pdfbox und FileUtils Allgemeine Java-Themen 2
O Frage zur Implementierungsweise Allgemeine Java-Themen 4
B Frage zu Bitshift Allgemeine Java-Themen 3
J Java Zufallsgenerator (6 aus 49) Frage Allgemeine Java-Themen 7
L Frage zu RIA und GWT Allgemeine Java-Themen 0
P Concurrency Frage Allgemeine Java-Themen 8
M Frage zu Enumerations Allgemeine Java-Themen 2
F Unlimited Strength Policy. Frage Verbreitung der Anwendung Allgemeine Java-Themen 1
F Frage zur Library JTS Allgemeine Java-Themen 5
S Java Design Frage Allgemeine Java-Themen 10
E Reflection? Frage Allgemeine Java-Themen 4
C FileInputStream frage Allgemeine Java-Themen 6
G Polymorphie Programmdesign Frage Allgemeine Java-Themen 20
Uzi21 Frage zu NetBeans ( Console) Allgemeine Java-Themen 11
D Classpath Frage zum Java Resource Loading Allgemeine Java-Themen 2
G Frage zu JPA Allgemeine Java-Themen 1
S Methoden Frage Allgemeine Java-Themen 2
P MVC - Frage zu Model Allgemeine Java-Themen 4
K Frage zu Locks Allgemeine Java-Themen 1
S Frage zu abstract Allgemeine Java-Themen 5
M ArrayList<String> Frage Allgemeine Java-Themen 7
M OOP Design Frage Allgemeine Java-Themen 2
N Frage zur while-Schleife Allgemeine Java-Themen 18
T Best Practice Auslesen von Zeichenketten (Frage, Antworten, usw) Allgemeine Java-Themen 4
C Eine Frage zur Bearbeitungszeit Allgemeine Java-Themen 8
H Frage wegen Heap-Speicher Allgemeine Java-Themen 2
T Garbage Collection Frage Allgemeine Java-Themen 15
P Kurze Frage: aus einer File die Zeilenanzahl auslesen Allgemeine Java-Themen 9
D Frage zu Java und Umlauten / charsets Allgemeine Java-Themen 2
B Frage zu Java und OpenGL? Allgemeine Java-Themen 3
Q Kapselung Allgemeine Design- Frage Allgemeine Java-Themen 8
A eine test thread.join() frage Allgemeine Java-Themen 2
DStrohma LayoutManager Frage zum GridBagLayout Allgemeine Java-Themen 4
F Frage zu Regex möglich Allgemeine Java-Themen 4
H XML-File mit Java erzeugt Frage Allgemeine Java-Themen 10
D Frage und Antwort Programm, Problem bei Methodenaufruf Allgemeine Java-Themen 3
J NetBeans Frage bezüglich der Scanner-Klasse Allgemeine Java-Themen 6
H Java Vector Frage Allgemeine Java-Themen 9
W Frage... Allgemeine Java-Themen 29
R Frage zur topologischen Sortierung Allgemeine Java-Themen 2
H Frage zu weka.core.Instance Allgemeine Java-Themen 3
Y Kleine Frage zu String.split Allgemeine Java-Themen 3
T Frage zu Klassendesing Allgemeine Java-Themen 3
W Frage zu Refactoring statischer Methoden Allgemeine Java-Themen 4
C Eclipse Wichtige frage Allgemeine Java-Themen 5
H Frage zu java.weka.core.Instances Allgemeine Java-Themen 3
S Frage zu Format Modifiers in Log4j Allgemeine Java-Themen 11
H Frage zu clone() Allgemeine Java-Themen 5
4 Simple(?) Frage zu Threads Allgemeine Java-Themen 14
H2SO3- SCJP Chapter 3 Frage 10. Falsche Antwort? Allgemeine Java-Themen 15

Ähnliche Java Themen

Neue Themen


Oben