Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Programmieren allgemein (https://www.delphipraxis.net/40-programmieren-allgemein/)
-   -   Java Callback für Delphi-DLL (https://www.delphipraxis.net/189035-java-callback-fuer-delphi-dll.html)

Benedikt Magnus 27. Apr 2016 20:23

Java Callback für Delphi-DLL
 
Hallo zusammen,

da ich lieber mit Delphi programmiere (bzw. Java nicht besonders schätze... :-D), möchte ich in einem Javaprogramm eine Delphi-DLL einbinden. Das klappt mit JNA auch ziemlich gut. Ich mache (auf Grundlage dieses Threads) das Ganze wie folgt:
Code:
public class Delphi
{

  public interface Lib extends Library
  {
    Lib TESTDLL = (Lib)Native.loadLibrary("TestDLL", Lib.class);
    int addiere(int zahl1, int zahl2);
  }

  public static void main(String[] args)
  {
    Lib.TESTDLL.addiere(17,4);
  }
}
Klappt auch super!

Jetzt das Knifflige: Die Delphi-DLL soll ebenfalls in der Lage sein, Funktionen aus dem Javaprogramm aufzurufen. "Kein Problem", sagte ich in meiner delphiverwöhnten Naivität, "machen wir das doch ganz einfach mit Methodenzeigern". Pustekuchen. Die gibts nämlich nicht in Java.
Nach einiger Recherche bin ich dann auf die Callbacks in JNA gestoßen (siehe hier, hier, hier und hier). Die sehen ziemlich vielversprechend aus, doch so ganz kapiere ich das wohl noch nicht.

Angenommen ich habe in der Delphi-DLL eine Funktion "addiere(a: Integer): Integer" und im Javaprogramm eine "int getSecondSummand(int id)", wie schaffe ich es nun, dass ich im Javaprgramm "addiere" und in der Delphi-DLL "getSecondSummand" aufrufen kann?

Benedikt Magnus 29. Apr 2016 12:24

AW: Java Callback für Delphi-DLL
 
Kann mir keiner weiterhelfen?

JasonDX 29. Apr 2016 12:52

AW: Java Callback für Delphi-DLL
 
Eine kurze Recherche im www hat dies hier ausgespuckt. Das scheint ein recht einfaches Beispiel mit Java und Delphi code zu sein, das an dein Beispiel anpassbar sein sollte. (Beachte dass der Code den Bug mit stdcall hat, wie in der Antwort darunter beschrieben).

Ich frage mich dennoch, was du dir davon erhoffst, Delphi und Java zu kombinieren. Die Schnittstelle wird chaotisch ohne Ende, Portabilität wird gleich 0, die technischen Schulden werden schnell unbezahlbar, und ich kann zumindest keinen Vorteil erkennen. Ich würde empfehlen eine Sprache zu wählen, und das Projekt in der zu realisieren. Wenn dir jemand anderes Java vorschreibt, wird diese Lösung keine Abnehmer finden.

Benedikt Magnus 29. Apr 2016 15:30

AW: Java Callback für Delphi-DLL
 
Oh, vielen, vielen Dank! Es funktioniert blendend! :thumb:
Habe die Aufrufkonvention delphiseitig auf cdecl gesetzt, soll nämlich sowieso ebenfalls auf Linux laufen.

Ich stimme dir da vollkommen zu. Im professionellen Kontext würde ich das auch eher nicht so durchführen. :-D
Aber ein paar Freunde und ich wollen im privaten Rahmen das Spiel Minecraft, insbesondere den Server, modifizieren (weshalb ein Umschreiben ganz zu Delphi entfällt). Java ist dafür aber seeehr lästig, zumal keiner von uns darin Erfahrung hat.
Als Interface, so wie es nun funktioniert, dürfte das aber produktiv machbar sein.
Wir haben dadurch zwei Vorteile: Zum einen können wir in einer Sprache schreiben, die wir sehr gut beherrschen. Zum anderen können wir, ohne uns in die Untiefen der doch (im Vergleich zu Delphi) sehr kryptischen Sprache Java zu begeben, einiges an Code optimieren.

hanvas 29. Apr 2016 20:32

AW: Java Callback für Delphi-DLL
 
Zitat:

Zitat von Benedikt Magnus (Beitrag 1337121)
Oh, vielen, vielen Dank! Es funktioniert blendend! :thumb:
Aber ein paar Freunde und ich wollen im privaten Rahmen das Spiel Minecraft, insbesondere den Server, modifizieren (weshalb ein Umschreiben ganz zu Delphi entfällt). Java ist dafür aber seeehr lästig, zumal keiner von uns darin Erfahrung hat.

Dann könntest Du auch FPC verwenden. Freepascal kann gegen die JVM compilieren und natürlich auch Java Libraries verwenden.

http://wiki.freepascal.org/FPC_JVM/Usage
http://wiki.freepascal.org/Lazarus_JVM

cu Ha-Jö

Benedikt Magnus 29. Apr 2016 20:48

AW: Java Callback für Delphi-DLL
 
Wäre so aber die Integration nicht noch schwieriger?
Ganz zu schweigen von der Performance, oder irre ich mich da?

BUG 29. Apr 2016 23:34

AW: Java Callback für Delphi-DLL
 
Zitat:

Zitat von Benedikt Magnus (Beitrag 1337156)
Ganz zu schweigen von der Performance, oder irre ich mich da?

Ich stelle mal frech die Behauptung auf, das es weniger kostet, euren Code in der JVM auszuführen als für jeden Aufruf mehrfach durch die JNA zu gehen. Kommt natürlich immer darauf an.

Aber FreePascal ist eine gute Idee. Wenn ihr es geschickt anstellt, könnt ihr euren Code sowohl mit Delphi, als auch mit FPC zu kompilieren. Dann könnt ihr herausfinden ob das mit der JNA schneller ist :stupid:

Benedikt Magnus 1. Mai 2016 12:39

AW: Java Callback für Delphi-DLL
 
Okay, ich habe mal ein paar plumpe Tests gemacht, FPC/JVM ist tatsächlich schneller, sogar recht eindeutig (ca. um den Faktor zehn) zumindest bei Aufrufen von Methoden mit Parametern.
JNI wäre theoretisch noch etwas schneller als JNA, aber das scheint mir auch noch komplizierter zu sein... :-D

Ich habe es jetzt mit JNA gut hinbekommen und werde dabei wohl auch bleiben (FPC ist da leider noch zu unbequem und die Integration des bestehenden Javacodes schwierig). Ist eben nur ein Hobbyprojekt.

Vielen Dank für eure Hilfe!


Alle Zeitangaben in WEZ +1. Es ist jetzt 01:25 Uhr.

Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz