Zum Inhalt springen

Empfohlene Beiträge

Geschrieben

Hallo ihr,

ich möchte Daten von einem Delphiprogramm an eine in C++ geschriebene DLL übertragen. Und möchte nun herrausfinden auf was ich da alles achten muss.

Ich habe schon erfolgreich primitven Datentypen von Delphi an die C++ DLL geschickt das klappt also soweit.

Nun habe ich zum Test mal ein Array vom typ double von Delphi an C++ geschickt. Doch wenn ich mir dann das Array anschaue was in C++ ankomme stehen da zwar die Werte drinne die ich von Delphiseite her reingebe. Jedoch wird das 2. Element des Arrays an der letzten Stelle des doubles verfälscht.

Nun wollte ich wissen ob das ganz normale ungenaugkeiten sind die durch den EInsatz von Fließkommazahlen kommen oder ob ich da etwas nicht beachtet habe.

Hier nun ein bisschen Quellcode für euch:

Delphi



type Daten = record

doubles : array[0..3] of double;

end;



// das sind die Werte die der record annimmt

 m_OptiData.doubles[0]:=1.337;

  m_OptiData.doubles[1]:=1.338;

   m_OptiData.doubles[2]:=1.339;



C++ Seite:
struct Daten

{


	double doubles[3];




};





DLLEXPORT int __stdcall MOPTI_execute(ROptimizationData * pData)

{


// daten testweise auf console ausgeben


	cout << pData->doubles[0] << endl;  // gibt 1.3370000000000000 aus

	cout << pData->doubles[1] << endl; // gibt 1.3380000000000001 aus

	cout << pData->doubles[2] << endl; // gibt 1.3390000000000000 aus



Geschrieben

Ich würde sagen, das sind die ganz normalen Ungenauigkeiten bei Fließkommatypen. Du könntest das prüfen, indem du in C++ testweise einem der doubles vor der Ausgabe den Wert 1.338 zuweist.

Geschrieben

OK ja sind die ganz normalen Ungenauigkeiten von double.

Jetzt noch die Frage ob jemand sowas schonmal gemacht hat und da Erfahrungen hat auf was man so achten sollte?

Im Endeffekt sollen records von Delphi an C++ übergeben werden.

DIese Records bestehen aus arrays von daten und auch wiederum teilweise aus records. (Also nur die Grundstruktur ist festgelegt (z.b. record record array array record record) nicht aber die anzahl der Elemente im Array z.B)

Erstelle ein Benutzerkonto oder melde Dich an, um zu kommentieren

Du musst ein Benutzerkonto haben, um einen Kommentar verfassen zu können

Benutzerkonto erstellen

Neues Benutzerkonto für unsere Community erstellen. Es ist einfach!

Neues Benutzerkonto erstellen

Anmelden

Du hast bereits ein Benutzerkonto? Melde Dich hier an.

Jetzt anmelden

Fachinformatiker.de, 2024 by SE Internet Services

fidelogo_small.png

Schicke uns eine Nachricht!

Fachinformatiker.de ist die größte IT-Community
rund um Ausbildung, Job, Weiterbildung für IT-Fachkräfte.

Fachinformatiker.de App

Download on the App Store
Get it on Google Play

Kontakt

Hier werben?
Oder sende eine E-Mail an

Social media u. feeds

Jobboard für Fachinformatiker und IT-Fachkräfte

×
×
  • Neu erstellen...