Performance Messungen

bene2808

Aktives Mitglied
Hi,

ich weiß, Performance Messungen in Java sind sowieso so eine Sache, wegen Virtueller Maschine etc etc. Aber wenn man Tests wiederholt, sollten sich doch zumindest Tendenzen ergeben. Ich habe folgenden Test geschrieben, der einmal in einer Schleife eine einzelne Variable erhöht und einmal zwei Variablen erhöht und die Zeit misst:

Java:
public class PerformanceTest {
    private static final long count = Integer.MAX_VALUE * 2L;
    private static final int testCount = 10;
    private static long startTime;
   
    public static void main(String[] args) {
        test1();
        test2();
    }
   
    private static void test1() {
        final long[] array = new long[testCount];
        for (int test = 0; test < testCount; ++test) {
            start();
            long a = 0;
            while (a < count) {
                a++;
            }
            stop();
            array[test] = a;
        }
        System.out.println(array);
    }
   
    private static void test2() {
        final long[] array1 = new long[testCount];
        final long[] array2 = new long[testCount];
        for (int test = 0; test < testCount; ++test) {
            start();
            long a = 0;
            long b = 0;
            while (a < count) {
                a++;
                b++;
            }
            stop();
            array1[test] = a;
            array2[test] = b;
        }
        System.out.println(array1 + ", " + array2);
    }
   
    private static void start() {
        startTime = System.currentTimeMillis();
    }
   
    private static void stop() {
        final long endTime = System.currentTimeMillis();
        System.out.printf("time: %d\n", endTime - startTime);
    }
}

Überraschenderweise kriege ich hier konstant bei test2 bessere Laufzeit (pro Test ca. 2,2s) als in test1 (pro Test ca. 3s), selbst wenn ich die beiden Tests in umgekehrter Reihenfolge ausführe. Woran kann das denn liegen? Oder habe ich irgendeinen komplett idiotischen Fehler gemacht?
 

LimDul

Top Contributor
Neben der Anmerkung von @thecain behaupte ich, dass bei so einem künstlichen Beispiel Dinge passieren, von denen man gar nichts weiß.

Die virtuelle Maschine macht Optimierungen: https://de.wikipedia.org/wiki/HotSpot

Es ist nicht auszuschließen, das aufgrund der Tatsache das in test2 mehr Anweisungen in der Schleife stehen eine Optimierung früher greift als bei test1 und im Endeffekt damit test2 schneller ist. Ist jetzt auch nur Kaffeesatzleserei von mir - aber bei so einem Konstrukt mit einer sich selbst optimierenden virtuellen Maschine ist die Aussagekraft solcher künstlichen, minimalen Tests extrem begrenzt - weil es eben keine realistischen Szenarien sind und man nicht alle Einflussgrößen kennt.
 

bene2808

Aktives Mitglied
Danke schon mal für die Antworten!:)


Gehört jetzt vielleicht nicht mehr ganz zum Thema, aber bin ein Maven Anfänger und kriege folgenden Fehler, wenn ich diesen Befehl:

mvn archetype:generate -DinteractiveMode=false -DarchetypeGroupId=org.openjdk.jmh -DarchetypeArtifactId=jmh-java-benchmark-archetype

im Wurzelverzeichnis des Projekts ausführe:

Failed to execute goal org.apache.maven.plugins:maven-archetype-plugin:3.1.2:generate (default-cli) on project test: The desired archetype does not exist (org:jmh-java-benchmark-archetype:1.0)
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
8u3631984 Frage Performance bei Linked List und Array List Allgemeine Java-Themen 5
H Performance einer Monte-Carlo-Simulation verbessern Allgemeine Java-Themen 6
goldmensch Datentypen Welche Methode hat die bessere Performance? Allgemeine Java-Themen 12
H Watson-Crick-Complement Performance Allgemeine Java-Themen 18
L Best Practice Auslagerung von Code = Performance Optimierung? Allgemeine Java-Themen 4
J Threads verbessern die Performance NICHT ? Allgemeine Java-Themen 8
X Performance für Tomcat / Apache optimieren Allgemeine Java-Themen 2
I Performance - JDBC UPC PoolDataSoure Allgemeine Java-Themen 0
E Lambda filter performance Allgemeine Java-Themen 2
D Performance-Probleme mit Joda-Time Allgemeine Java-Themen 3
A Jasper Report Performance bei PDF erzeugen Allgemeine Java-Themen 0
A Best Practice Variablen vertauschen - Performance Allgemeine Java-Themen 1
R DBUnit Performance Probleme Allgemeine Java-Themen 0
P Performance: super explizit erwähnen oder weglassen? Allgemeine Java-Themen 5
S starke performance probleme des forums Allgemeine Java-Themen 10
C Performance Tips Allgemeine Java-Themen 13
A Performance/Speicherplatz-Nutzung bei Tests Allgemeine Java-Themen 6
R Java Performance testen Allgemeine Java-Themen 18
StrikeTom Java Performance Fragen Allgemeine Java-Themen 5
V Performance steigern Allgemeine Java-Themen 7
D Reflection-Performance Allgemeine Java-Themen 7
M Einfluss von Caching auf die Performance (große Arrays) Allgemeine Java-Themen 24
R Collections Performance einer HashMap Allgemeine Java-Themen 26
i<3java [Groovy/Grails](oder auch java) Mögliche Performance Probleme bei Mailversendung Allgemeine Java-Themen 2
D Performance Objektallokation Allgemeine Java-Themen 28
J Java Performance nicht nachvollziehbar Allgemeine Java-Themen 3
I Library für High Performance Mime Type Erkennung Allgemeine Java-Themen 8
S Performance Frage: Objekt oder static? Allgemeine Java-Themen 33
M Runtime.exec() - Performance / Frage zu Threads Allgemeine Java-Themen 5
M Performance Allgemeine Java-Themen 6
M Performance Allgemeine Java-Themen 5
E Performance website download Allgemeine Java-Themen 13
MQue Performance Methodenaufruf - if Abfrage Allgemeine Java-Themen 19
hdi Was frisst in meinem Programm den Speicher / verschlechtert die Performance Allgemeine Java-Themen 11
J Performance von Java GUI-Anwendungen Allgemeine Java-Themen 2
U Java Performance im Vergleich zu C++ in speziellem Anwendungsfall Allgemeine Java-Themen 6
S Performance und Function Call Depth Allgemeine Java-Themen 6
H Performance Vorteil durch Wechsel der JVM? Allgemeine Java-Themen 6
A Performance: byte[] in byte[][][] konvertieren Allgemeine Java-Themen 2
T Performance ArrayList#remove Allgemeine Java-Themen 8
ARadauer Performance Pptimierung -Lesen/Schreiben Allgemeine Java-Themen 10
Chris81T Performance Problem durch mehrfaches Starten eines JAVA Prog Allgemeine Java-Themen 8
G Hibernate, JTable und Performance Allgemeine Java-Themen 17
M Listener und Performance Allgemeine Java-Themen 9
P Performance: Ziehen ohne Zurücklegen (große Datenmenge) Allgemeine Java-Themen 10
D Performance: ArrayList vs. Array vs. "Eigene Liste&quot Allgemeine Java-Themen 8
M nichtreferenzierte Objekte auf NULL setzen -> Performance Allgemeine Java-Themen 4
S Ursache für schlechte Performance Allgemeine Java-Themen 2
L Java Performance Check Tool Allgemeine Java-Themen 3
S Performance von Comparator Allgemeine Java-Themen 3
egrath Performance Problem mit File-I/O Allgemeine Java-Themen 6
S Performance Problem Allgemeine Java-Themen 11
X Java Performance auf Sun Systemen bzw. generell Allgemeine Java-Themen 4
T Performance String-Operationen und StringBuffer (1.4und 1.5) Allgemeine Java-Themen 18
P miese performance bei nem BufferedImage + repaint :( Allgemeine Java-Themen 6
T Performance-Grundlagen Allgemeine Java-Themen 4
G Performance Problem bei der Übertragung Server zum Client Allgemeine Java-Themen 3
V Performance Leck finden Allgemeine Java-Themen 3
T Tile Game Performance Allgemeine Java-Themen 32
M Performance enorm langsam Allgemeine Java-Themen 26
F Performance von Reflection vs Statisches Coden Allgemeine Java-Themen 4
M Performance: Java zu C/C++ bei Datenbankanwendung Allgemeine Java-Themen 3
Y unnecessary cast & Performance Allgemeine Java-Themen 29
conan2 Performance von paint() Allgemeine Java-Themen 2
G Performance JDOM - DOM - eigene HashMap (SAX) Allgemeine Java-Themen 2
F Bilder als "Thumbnails" laden - Performance Allgemeine Java-Themen 6
S Java3D Performance optimieren Allgemeine Java-Themen 5
F Wenn ihr Performance wollt nehmt C++ Allgemeine Java-Themen 39
N Performance-Test (Geschwindigkeit von Methoden vergleichen)? Allgemeine Java-Themen 4
S Performance Test mit JMeter Allgemeine Java-Themen 2
T Performance Allgemeine Java-Themen 8
J Anfängerliste für gute Performance? Allgemeine Java-Themen 3
Luma Performance-Problem mit RandomAcces File Allgemeine Java-Themen 4
I Performance bei "String <-> Byte"-Umwandlung Allgemeine Java-Themen 4
I Performance-Probleme bei Schleife Allgemeine Java-Themen 3
C Performance von FOR Schleifen Allgemeine Java-Themen 25
C Performance Vergleich, Java vs. Tcl/Tk Allgemeine Java-Themen 3

Ähnliche Java Themen

Neue Themen


Oben