![]() |
AW: C# DLL in Delphi nutzen
Delphi-Quellcode:
hat den Vorteil des Lazy Loadings. Wenn die DLL also nicht beim Programmstart direkt zur Verfügung stehe muss, dann kann man die auch erst verzögert laden. Macht den Anwendungsstart ggf. auch etwas schneller.
LoadLibrary()
Und nur weil das Attribut darüber steht heißt das bei C# nicht zwangsläufig, dass die Methode auch exportiert wird. Zumindest ist das meine Erfahrung. |
AW: C# DLL in Delphi nutzen
Zitat:
Meine Erfahrung entspricht deinem Gegenteil. aber muß mich nicht streiten. |
AW: C# DLL in Delphi nutzen
Hallo,
unter c++ wird an den Methodennamen immer was drangehangen, vielleicht ist es in c# ja auch so. |
AW: C# DLL in Delphi nutzen
Du musst die Zielplattform im c# Projekt auf x86 setzten.
Die Declaration von
Delphi-Quellcode:
mit Rückgabe String wird auch nicht funktionieren.
function ConvertToJson(pBytes: Pbyte; cBytes: Integer): string; stdcall; external 'MsgPack.Native.dll';
Versuche es mit PWChar |
AW: C# DLL in Delphi nutzen
Müsste es nicht
ConverToJson := GetProcAddress(dllhandle, 'ConvertToJson'); heißen? Und evtl WideString anstatt String in der Deklaration der Funktion. Das mit 32bit und 64bit ist immer etwas schwierig einzustellen in VS finde ich. Nutzt Du DLLExport 1.7.4.? Al Beispiel mal mein Projekt ![]() |
AW: C# DLL in Delphi nutzen
Zitat:
bzgl. x86 und x64 ist so ein Problem. Was bringt es wenn die Bibliothek RGiesecke.DllExport mit AnyCPU kompiliert wurde das beißt sich doch irgendwie. Delphi DLL -> C# über DllImport ist kein Problem. C# DLL über DllExport hingegen schon. (Leider) bsp.
Code:
Delphi.
namespace CalcTest
{ using System.Runtime.InteropServices; using RGiesecke.DllExport; public sealed class CalcTest { [DllExport(CallingConvention = CallingConvention.StdCall)] public static int Sum(int a, int b) { return a + b; } } }
Delphi-Quellcode:
function Sum(a, b: integer): integer; stdcall; external 'Calctest.Net.dll';
Delphi Anwendung stürzt sofort ab.. läßt sich nicht starten! Fehler! Der Fehler 0xc000007b tritt typischerweise auf, wenn die 32-Bit-Version von Windows mit einem 64-Bit-Betriebssystem oder -Anwendungen verwechselt wurde. Projekt ist aber x86 C# DLL ebenso jedoch RGiesecke.DllExport AnyCPU .. EDIT: RGiesecke.DllExport neu kompiliert 32Bit\x86 alle Frameworks 4.8 trotzdem selber Fehler. |
AW: C# DLL in Delphi nutzen
Also mit der Lib von Robert Giesecke war irgend wann Ende im Gelände. Bin dann zu DLLExport gewechselt, was grob auf RGiesecke basiert, aber eine Neuentwicklung ist.
|
AW: C# DLL in Delphi nutzen
Zitat:
|
AW: C# DLL in Delphi nutzen
Damit funktioniert es nun.
Offline Package von DLLExport im Archiv. genug damit gespielt. Wenn er nun das als Beispiel nimmt und sein Projekt entsprechend anpaßt wird es wohl funktionieren. ![]() Danke an @sh17 für die Info. Werde die Anhänge später wieder löschen. |
AW: C# DLL in Delphi nutzen
Zitat:
|
Alle Zeitangaben in WEZ +1. Es ist jetzt 19:58 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz