JNA - JNI - pures Java - Vergleich

P

pmias

Gast
Hallo Forum,

ich war neulich einmal neugierig, wie groß der Geschwindigkeitsvorteil von JNA und JNI gegenüber purer Java-Implementierung ist. Immerhin ist dies einer der Argumente der nativen Implementierung in C, etc.

Als Test habe ich folgenden Algorithmus sowohl in einer Java-Methode, als auch als zwei externe native Libraries in C implementiert und rufe sie mit JNI bzw. JNA auf:

Java:
double iterate(int steps)
   {
   double v = 1;
		  
   int i;
   for (i=1; i<=steps; i++) v /= i;
		  
   return v;
   }

Der Rückgabewert sei hier erst einmal zweitrangig. Es ging mir primär darum, den PC erst einmal in der Schleife zu beschäftigen. Alle zwei C-Implementierungen ließen sich auf meinem Linux-System kompilieren und anstandslos aufrufen.

Um das Zeitverhalten zu testen, habe ich diese Methode mit steps=2100000000 aufgerufen und den Aufruf 20x in einer Schleife wiederholt (Stichwort: Java Runtime Optimierung).

Das Ergebnis hat mich doch überrascht. Als Durchschnittszeiten gerundet kamen bei meinem PC heraus:

- 14 s (Java pur)
- 19 s (JNI)
- 28 s (JNA)

Gut, ich weiß, daß JNA langsamer als JNI ist. Aber ich hätte ehrlich erwartet, daß beide Varianten immer noch schneller als pures Java wären, wenn es um Berechnungen geht.

Kann diese Relationen irgendwer bestätigen? Muß man vielleicht noch dem Compiler ein wenig gut zureden, indem man ihm weitere Parameter mitgibt? Oder ist eine simple for-Schleife mit Division nicht zu optimieren - wenn nicht, was dann?
 

Marco13

Top Contributor
So ein "Benchmark" ist höchst fragwürdig. Bei so kleinen Dingen ist da mit nativen Anbindungen nicht viel rauszuholen. Allein der native Aufruf dauert einen Moment (bei kleinerem Input und mehr Aufrufen würde das noch deutlicher ins Gewicht fallen). Das systematisch zu vergleichen und alles in Relation zu stellen wäre aufwändiger....
Das Vorurteil, Java sei langsam, stammt aus... den 90ern des letzten Jahrhunderts. Vielleicht könnte man durch irgendwelche Compilerflags (auf nativer Seite) noch was rausholen, vielleicht auch durch irgendwelche Tricks und Kniffe an der JVM (es gibt einen haufen undokumentierter Parameter), aber der Aufwand ist es i.A. nicht wert. Wenn es um reines numbercrunching geht, kann man höchstens dann etwas schneller machen, wenn man datenparallele Aufgaben hat, die man auf die GPU auslagern kann.
 

ice-breaker

Top Contributor
Das Problem bei solchen Microbenchmarks ist einfach, dass es wirklich absolut davon abhängt, was der JIT/C-Compiler daraus macht.
Java könnte sogar hingehen und könnte sagen, dass es die Ergebnisse von iterate bei einer gegebenen Steps-Zahl cached (ich weiß nicht ob es die Optimierung cached).
Der GCC könnte, wenn er intelligent genug wäre, aber auch gleiche deine ganze Schleife wegoptimieren:
Java:
double iterate(int steps) {
  return 1.0 / (steps * (steps + 1) / 2);
}
(funktioniert nur bei positiven Steps)

Probier es doch mal mit den Benchmarks aus dem "Computer Language Benchmarks Game". Diese machen etwas mehr Logik wodurch der JNI/JNA-Aufrufoverhead im Gesammtkontext nicht mehr so relevant sein sollte.


Btw.: hast du gcc den Code optimieren lassen (-O3) ?
 
Zuletzt bearbeitet:
P

pmias

Gast
Mir ist schon klar, daß man die Sekunden nicht so genau nehmen darf. Und daß der Aufruf der nativen Libs auch einiges kostet. Genau deshalb hab ich ja so eine Schleife in die Libs selbst verlagert, so daß der Aufruf kaum noch ins Gewicht fallen sollte.

Wenn ich den Aufruf mit nur 2.000.000 tätige, dann bin ich bei allen Methoden unter einer Sekunde. Das würde bedeuten, daß der reine Aufruf der nativen Libs noch relativ schnell erledigt ist. Daraus würde ich jetzt folgern, daß die restlichen Zeiten in der Schleife selbst anfallen. Das wiederum wird durch den direkten Aufruft der C-Funktion von einer C-Main-Funktion aus belegt (ca. 3 sek.).

Ich frage mich jetzt nur, was da so lange dauert. In so ziemlich jedem JNI/JNA-Tutorial wird behauptet, daß Berechnungen schneller wären, würde man sie auslagern. Und, ja ich weiß, daß Java schneller ist, als sein Ruf. Genau deshalb habe ich diesen Praxistest ja gemacht. Ab wann macht es wirklich Sinn, eine komplexe Berechnung auszulagern oder doch lieber in Java zu implementieren, geht es um Geschwindigkeit?
 
P

pmias

Gast
@ice-breaker

Danke für die Anregungen, werde es demnächst testen. Nein, ich habe noch keine Optimierungen vorgenommen, ich wollte am Anfang alles möglichst ohne Spezialeinstellungen testen. Wie im obigen Post schon erwähnt, möchte ich rausfinden, ab wann eine Auslagerung komplexer Berechnungen wirklich Sinn macht.
 

ice-breaker

Top Contributor
Wenigstens der GCC-Compiler sollte aber sein Compilerflag bekommen, sonst ist dein Benchmark nämlich vom Konzept unfair ;)
Der JIT-Compiler von Java optimiert automatisch und dein C-Code läuft unoptimiert einfach nur 1:1 in Maschinencode übersetzt ;)

Mach doch nochmal schnell das Optimierungsflag rein und teste es nochmal fix mit -O3, es würde mich echt interessieren, wie groß der Unterschied dann noch ist.

An Introduction to GCC - Optimization levels
 
Zuletzt bearbeitet:

Ark

Top Contributor
Wenigstens der GCC-Compiler sollte aber sein Compilerflag bekommen, sonst ist dein Benchmark nämlich vom Konzept unfair ;)
Der JIT-Compiler von Java optimiert automatisch und dein C-Code läuft unoptimiert einfach nur 1:1 in Maschinencode übersetzt ;)
Und es kommt noch schlimmer: Im Gegensatz zu einem dynamisch optimierenden Compiler kann der GCC nur statisch optimieren. Soll heißen: der HotSpot-Compiler kann ein Stück Code mal so, mal anders optimieren, weil er zur Laufzeit Informationen vorliegen hat, die ihm garantieren, dass die jeweilige Optimierung möglich ist, ohne die Semantik zu ändern.

Dagegen kann es gut sein, dass der GCC weder die eine noch die andere Optimierung vornehmen kann, weil er nicht garantieren kann, dass die Semantik dabei unverändert erhalten bleibt.

Ark
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
D Hat Java eine Library um JavaScript auszuwerten? Allgemeine Java-Themen 2
Zrebna Wieso sind eigentlich JUnit-Tests in src/test/java platziert - nur Konvention? Allgemeine Java-Themen 7
N LlaMA, KI, java-llama.cpp Allgemeine Java-Themen 39
V Java-Codierungsherausforderung: Navigieren durch die Macken der Datumsmanipulation Allgemeine Java-Themen 2
E Output Fehler (Java-Programm Kuchen) Allgemeine Java-Themen 11
M java: unexpected type Allgemeine Java-Themen 2
harrytut Java Input/Output Tests Junit Allgemeine Java-Themen 3
B Java Discord bot auf ein Root Server? Allgemeine Java-Themen 1
BetziTheRealOne Java PKIX path building failed as non Admin Allgemeine Java-Themen 15
D Linux, Java-Version wird nicht erkannt bzw. welche Einstellung fehlt noch? Allgemeine Java-Themen 19
KonradN Java 21 Release Allgemeine Java-Themen 5
V Umgang mit fehlenden Daten in einer Java-Datenanalyseanwendung Allgemeine Java-Themen 5
P Fehler: Hauptklasse Main konnte nicht gefunden oder geladen werden Ursache: java.lang.ClassNotFoundException: Main Allgemeine Java-Themen 24
K Java Anwendung machen Anleitung Allgemeine Java-Themen 5
G java.io.listFiles() Allgemeine Java-Themen 3
8u3631984 Frage zu Java Streams min / max Allgemeine Java-Themen 17
S Java Programm lässt sich vom USB-Stick starten, aber nicht von HDD Allgemeine Java-Themen 16
K Java-Projekt Allgemeine Java-Themen 11
K Java-Projekt Allgemeine Java-Themen 0
ruutaiokwu Welcher Browser unterstützt heutzutage noch Java Applets? Allgemeine Java-Themen 5
Jose05 Java-Klasse im extra cmd-Fenster ausführen Allgemeine Java-Themen 3
rode45e Java Threads Allgemeine Java-Themen 4
G java.io.listFiles() Allgemeine Java-Themen 2
N Java Dynamic Proxy Allgemeine Java-Themen 3
N Leichte Java Gegner Ki Allgemeine Java-Themen 10
A Java modul Problem Allgemeine Java-Themen 4
Thomasneuling Java Jar datei erstellen, von Projekt, dass auch Javafx Dateien, FXML Dateien und CSS Dateien, sowie Bilder enthält? Allgemeine Java-Themen 14
V Funktionale Schnittstelle in Java Allgemeine Java-Themen 3
OnDemand Java String in Hashmap als Key NULL Allgemeine Java-Themen 27
urmelausdemeis Exception in thread "main" java.lang.Error: Unresolved compilation problem: Allgemeine Java-Themen 7
berserkerdq2 Wenn ich bei Intelij javafx mit maven importieren will, muss ich das in die pom.xml reintun, aber warum noch in module-info.java? Allgemeine Java-Themen 3
KonradN Java 20 am 21. März Allgemeine Java-Themen 1
O Java Website Stock Bot Allgemeine Java-Themen 3
J Front-/Backend in Java Allgemeine Java-Themen 14
doopexxx JAVA Google Webcrawler Allgemeine Java-Themen 1
J JavaScript innerhalb eines Java Projekts ausführen Allgemeine Java-Themen 2
A Java Programm erstellen hilfe Allgemeine Java-Themen 10
G java.lang.NoClassDefFoundError: org/aspectj/lang/Signature Allgemeine Java-Themen 2
lalex1491 Java Aktienkurse nachfragen Allgemeine Java-Themen 4
J Class to link Java Allgemeine Java-Themen 4
V Wie funktioniert das Schlüsselwort "final" von Java? Allgemeine Java-Themen 19
mrStudent Inferenz JAVA Allgemeine Java-Themen 6
U URI Rechner (Java Script) Allgemeine Java-Themen 7
TheSkyRider Java Geburtsdatum Textfeld Allgemeine Java-Themen 7
mihe7 Java 19 JavaDocs: Browserintegration Allgemeine Java-Themen 0
Encera Gleichzeitiges Ausführen und verbinden von 2 Java-Klassen über die Eingabeaufforderung und Eclipse Allgemeine Java-Themen 21
H Java Rechner Programmierung der Mathematik Allgemeine Java-Themen 33
Lennox Schinkel Java Kara Auf einen Java Host laufen lassen Allgemeine Java-Themen 17
C Fußnoten von DocX mit Java Allgemeine Java-Themen 2
C Fußnoten in DocX mit Java Allgemeine Java-Themen 1
M Aussagenlogik in Java Programmieren Allgemeine Java-Themen 22
B Per Java Word Dokument schreiben? Allgemeine Java-Themen 8
krgewb Java-Bibliothek für ONVIF Allgemeine Java-Themen 1
KonradN Oracle übergibt (Java Teile der) GraalVM Community Edition an OpenJDK Community Allgemeine Java-Themen 2
Momo16 Brauche Hilfe - Java Projekt kann nicht erstellt werden Allgemeine Java-Themen 12
B Java mit command line und jars benutzen? Allgemeine Java-Themen 18
M Java Überprüfen ob .exe-Datei bereits ausgeführt wird Allgemeine Java-Themen 2
B HTTP Allgemeine Fragen über Suchmaschine nutzen mit Java Allgemeine Java-Themen 20
Mick P. F. Wie kriege ich die Fehlermeldung "java: symbol lookup error: ..." weg? Allgemeine Java-Themen 11
K Nachhilfe Java Allgemeine Java-Themen 11
KonradN Java 19 Allgemeine Java-Themen 11
F IDEA IntelliJ Java Songliste erstellen Allgemeine Java-Themen 6
TheSepp Java bestimmtes Array auf den Wert 0 setzen Allgemeine Java-Themen 32
B Java Reflection Probleme beim wehcselseitigen Referenzieren zweier Klassen/Objekte Allgemeine Java-Themen 14
Sachinbhatt Sind alle Methoden in Java implizit virtuell Allgemeine Java-Themen 2
E Java und integrierte Grafikkarten Allgemeine Java-Themen 18
Sachinbhatt Wie wird die Typumwandlung bei Mehrfachvererbung in Java implementiert? Allgemeine Java-Themen 3
Peterw73 Hilfe bei Java gesucht Allgemeine Java-Themen 3
A Java unter Win 10 Allgemeine Java-Themen 1
B Woher kommen die Bildschirmkoordinaten beim java Robot? Allgemeine Java-Themen 14
P9cman java.Lang Klassen fehlen in JRE System Library Allgemeine Java-Themen 1
T Java Robot Class - Bot Allgemeine Java-Themen 3
E Wie Java Heap Space vergrößern? Allgemeine Java-Themen 3
B Java Programm auf virutellem Desktop laufen lassen? Allgemeine Java-Themen 1
D VBA Code mit Java ausführen möglich? Allgemeine Java-Themen 10
berserkerdq2 Threads, wie genau läuft das in Java ab? (Ich kann Threads erstellen und nutzen, nur das Verständnis) Allgemeine Java-Themen 6
izoards Java Home Pfad unabhängig von der Version Allgemeine Java-Themen 7
N JAVA-Code mit Grafikfenster zeichnet in Windows, aber nicht Mac. Allgemeine Java-Themen 4
L Java überprüfen lassen, ob sich ein gegebener Pfad / das Programm an sich auf einer CD oder Festplatte befindet Allgemeine Java-Themen 14
KonradN CVE-2022-21449: Fehler in Java bei Signaturprüfung Allgemeine Java-Themen 20
berserkerdq2 Java sql Allgemeine Java-Themen 15
JordenJost Unverständlicher Java code? Allgemeine Java-Themen 21
LimDul XSD To Java - Überschreiben von Assoziationen Allgemeine Java-Themen 1
Aartiyadav Comparisons and Swapa in Bubble-sort Java Allgemeine Java-Themen 6
KonradN Java 18 Allgemeine Java-Themen 8
N Statistische Auswertung von Logfiles (Einlesen, auswerten und grafische Aufbereitung von logfiles) mit Java Allgemeine Java-Themen 9
ME2002 Fragen aus einer Java Klausur Allgemeine Java-Themen 67
Z Mit Java 8+ Streams Zeilen nummern zu Zeilen hinzufügen Allgemeine Java-Themen 17
M Verständnisfrage java.util.TimerTask Allgemeine Java-Themen 2
V Hilfe mit Java Code Allgemeine Java-Themen 4
S Processing Java Code verstehen Allgemeine Java-Themen 4
O Newton Algorithmus Java Allgemeine Java-Themen 1
P Java Quellen finden Allgemeine Java-Themen 3
M Java Analyse/ SWOT-Analyse Allgemeine Java-Themen 13
J c Programm läuft nicht in compilierter Version des Java Projektes Allgemeine Java-Themen 7
Atten007 Java-Klasse auf macOS entpacken? Allgemeine Java-Themen 2
E java mithilfe url .jar datei öffnen Allgemeine Java-Themen 9
M Warum hat Java dieses und jenes nicht... Allgemeine Java-Themen 8
E Java .exe Datei mit args starten Allgemeine Java-Themen 2
LimDul Kam eine java.net.URL zu einer HashMap und ging als DNS Anfrage wieder heraus Allgemeine Java-Themen 18

Ähnliche Java Themen

Neue Themen


Oben