Delphi-PRAXiS
Seite 1 von 2  1 2      

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Delphi Zugriffsverletzung beim erstellen eines Datamoduls (https://www.delphipraxis.net/209843-zugriffsverletzung-beim-erstellen-eines-datamoduls.html)

Delbor 30. Jan 2022 11:33

Datenbank: SQLite • Version: 3xxx • Zugriff über: FireDac

Zugriffsverletzung beim erstellen eines Datamoduls
 
Hi zusammen

Die Fehlermeldung:
Zitat:

---------------------------
Im Projekt HomeOfficerFEProject.exe ist eine Exception der Klasse $C0000005 mit der Meldung 'access violation at 0x008f8a29: read of address 0x00000090' aufgetreten.
---------------------------
Und der Ausllöser, die erste zeile:

Delphi-Quellcode:
procedure TDMLSQLiteOfficerFE.DataModuleCreate(Sender: TObject);
begin
  Self.FDMoniFlatFileClientLink1.Tracing := False;
  Self.FDMoniFlatFileClientLink1.FileName := ExtractFilePath(Application.ExeName) + '\trace.txt';
  Self.FDMoniFlatFileClientLink1.Tracing := true;
end;
Und wiedermal: Ich finde nirgendwo im Embarcadero Wicki Angaben darüber, für was dieses Objekt gut ist. Den einzigen Hinweis lieferte mir LEO (tracing wird offenbar mit dokumentieren/verfolgen gleichgesetzt...)

Umsomehr: das bewusste Objekt wurde zur Entwurfszeit gesetzt, hat keinen Activ-Schalter, und somit gibts für diese AV auch (scheinbar)keinen Grund.
Was, zum Kuckuck, mache ich falsch??

Gruss
Delbor

TiGü 30. Jan 2022 11:38

AW: Zugriffsverletzung beim erstellen eines Datamoduls
 
FDMoniFlatFileClientLink1 ist ungleich nil?
Wenn nein, dann ist das Rätsel schon gelöst.

Delbor 30. Jan 2022 12:00

AW: Zugriffsverletzung beim erstellen eines Datamoduls
 
Hi Tigü
Zitat:

FDMoniFlatFileClientLink1 ist ungleich nil?
Wenn nein, dann ist das Rätsel schon gelöst.
Du meinst, ich müsste das Ding zur Laufzeit erzeugen? Oder was verstehe ich jetzt falsch?

Gruss
Delbor

Uwe Raabe 30. Jan 2022 12:35

AW: Zugriffsverletzung beim erstellen eines Datamoduls
 
Zitat:

Zitat von Delbor (Beitrag 1501424)
Ich finde nirgendwo im Embarcadero Wicki Angaben darüber, für was dieses Objekt gut ist.

Ich schon: Ablaufverfolgung und Überwachung (FireDAC)

Zitat:

Zitat von Delbor (Beitrag 1501424)
Delphi-Quellcode:
procedure TDMLSQLiteOfficerFE.DataModuleCreate(Sender: TObject);
begin
  Self.FDMoniFlatFileClientLink1.Tracing := False;
  Self.FDMoniFlatFileClientLink1.FileName := ExtractFilePath(Application.ExeName) + '\trace.txt';
  Self.FDMoniFlatFileClientLink1.Tracing := true;
end;

Kann es sein, dass das Datenmodul von einem anderen abgeleitet ist und hier einfach ein inherited fehlt?

himitsu 30. Jan 2022 12:51

AW: Zugriffsverletzung beim erstellen eines Datamoduls
 
ExtractFilePath hat bereits einen \ am Ende. Wozu dann nochmal einen dazwischen?
Als einfaches Lösung gibt es seit Längerem Delphi-Referenz durchsuchenTPath.Combine.

Und wie wäre es, wenn man langsam mal lernt, wie der Debugger in Grundzügen zu benutzen ist?
Zitat:

FDMoniFlatFileClientLink1 ist ungleich nil?
Die Frage würde man sich dann selber beantworten können und jemand wüsste auch, wo weiter zu suchen ist.


Der Name FDMoniFlatFileClientLink1 klingt ja eher danach, als wenn die Komponente auf dem/der Datamodul/Form liegen sollte (im FormDesigner), was sie scheinbar nicht tut.


@Hersteller
Wenn die Hilfe absolut nichts zu sagen hat, was CodeInsight nicht auch schon kennst, dann darf die Hilfe auch gleich ganz gelöscht werden.
https://docwiki.embarcadero.com/Libr...FileClientLink

Delbor 30. Jan 2022 13:09

AW: Zugriffsverletzung beim erstellen eines Datamoduls
 
Hi Uwe Raabe

Zuerst mal vielen Dank für den interessanten Link!!

Zitat:

Kann es sein, dass das Datenmodul von einem anderen abgeleitet ist und hier einfach ein inherited fehlt?
Das Projekt ist nicht mehr ganz taufrisch. Von daher könnte es schon sein,das ich mal ein Datenmodul unter anderem Namen abgespeichert habe. Doch normalerweise erzeuge ich auch Datenmodule immer neu und popiere bewährten Code hinein. Trotzdem hab ich mal das inherited eingefügt - mit demselben Ergebnis.

@himitsu: Ich hab jetzt nur gerade mitgekriegt, dass du geposted hast und kurz mal reingeschaut:
Zitat:

ExtractFilePath hat bereits einen \ am Ende. Wozu dann nochmal einen dazwischen?
Zitat:

'/ /'
Das wäre also eine Lücke im Pfad. Nur schade, dass das nicht die ursache war.

Zitat:

Der Name FDMoniFlatFileClientLink1 klingt ja eher danach, als wenn die Komponente auf dem/der Datamodul/Form liegen sollte (im FormDesigner), was sie scheinbar nicht tut.
Eben doch. Und deswegen hab ich erst auch nach sowas wie Active oder Enabled gesucht.


Gruss
Delbor

Uwe Raabe 30. Jan 2022 14:46

AW: Zugriffsverletzung beim erstellen eines Datamoduls
 
Der Link erwähnt auch diesen Schritt:
Zitat:

Fügen Sie den Verbindungsdefinitionsparameter MonitorBy=Xxx hinzu.
Ist dies denn bei der betreffenden Connection gewährleistet? Ich würde es zwar auch für einen Fehler halten, wenn es ohne dies kracht, aber wir versuchen ja erstmal das ganze zum Laufen zu bringen.

Kannst du denn im Debugger (mit Debug-DCUs) sehen, wo genau das Problem liegt?

Delbor 30. Jan 2022 18:58

AW: Zugriffsverletzung beim erstellen eines Datamoduls
 
Liste der Anhänge anzeigen (Anzahl: 3)
Hi zusammen

Meine Schritte beim Debuggen :
Programmstart mit F9
Anhang 54839
Beim Datamodul.Create mit F7
Anhang 54840
und hier weiter bis zur ersten Boolean-Zuweisung - dann knallts.
und Self ist nil...
Anhang 54841

Gruss
Delbor

himitsu 30. Jan 2022 20:21

AW: Zugriffsverletzung beim erstellen eines Datamoduls
 
Wieso rufst DU das OnCreate des DataModuls auf?

Und warum hat vorher niemand das Datenmodul erstellt?

Delbor 30. Jan 2022 21:50

AW: Zugriffsverletzung beim erstellen eines Datamoduls
 
Hi himitsu

Zitat:

Zitat von himitsu (Beitrag 1501439)
Wieso rufst DU das OnCreate des DataModuls auf?

Das mache ich eigentlich immer so, da beim Create einiges zu erledigen ist. Aber dank dir habe ich da mal nachgesehen - es ist tatsächlich unter den automatisch erstellten Formularen...

Gruss
Delbor


Alle Zeitangaben in WEZ +1. Es ist jetzt 15:40 Uhr.
Seite 1 von 2  1 2      

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