AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

Zeitpunkt der Objekterstellung

Ein Thema von FriendOfDelphi · begonnen am 8. Jun 2010 · letzter Beitrag vom 8. Jun 2010
Antwort Antwort
FriendOfDelphi

Registriert seit: 21. Mai 2010
163 Beiträge
 
Delphi 5 Professional
 
#1

Zeitpunkt der Objekterstellung

  Alt 8. Jun 2010, 15:12
Delphi-Version: 2005
Hallo!

Folgendes Problem:

Es existieren mehrere Units.
Der Quellcode der einen Unit greift auf Objekte einer anderen Unit zu.

Die Fehlermeldung lautet:
Im Projekt Programm.exe ist eine Exception der Klasse EAccessViolation aufgetreten. Meldung: 'Zugriffsverletzung bei Adresse 004AC5B1 in Modul 'Programm.exe'. Lesen von Adresse 00000310'. Prozeß wurde angehalten. Mit Einzelne Anweisung oder Start fortsetzen.

Es liegt wohl daran, dass das Objekt auf welches zugegriffen werden soll zu diesem Zeitpunkt noch nicht existiert, da die Unit, in welcher dieses Objekt erstellt wird, erst danach verarbeitet wird. Dies habe ich im Einzelschrittmodus so nachvollziehen können.

Was kann man da machen?
Herzlichen Gruß
FriendOfDelphi
  Mit Zitat antworten Zitat
Benutzerbild von Mithrandir
Mithrandir
(CodeLib-Manager)

Registriert seit: 27. Nov 2008
Ort: Delmenhorst
2.379 Beiträge
 
#2

AW: Zeitpunkt der Objekterstellung

  Alt 8. Jun 2010, 15:17
Die Unit an Anfang der Uses-Klausel schreiben?
米斯蘭迪爾
"In einer Zeit universellen Betruges wird das Aussprechen der Wahrheit zu einem revolutionären Akt." -- 1984, George Orwell
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.184 Beiträge
 
Delphi 12 Athens
 
#3

AW: Zeitpunkt der Objekterstellung

  Alt 8. Jun 2010, 15:18
Bei Units, welche unter Interface eingebunden werden, wird die Initialisation immer vorher abgearbeitet, als die Initialisation der einbindenden Unit.

Bei Einbindung in der Implementation ist keine Reihenfolge sichergestellt.



Also entweder du greifst nur auf Units (und deren Inhalt) zu, welcher überimplementation eingebunden und rechtzeitig initialisiert werden.
Oder du prüfst beim Zugriff nach und verschiebst die Initialisation.

Letzeres z.B. so:
Delphi-Quellcode:
funktion gibObjekt: TObject;
begin
  if not assigned(globalVar) then
    globalVar := TMeinObjekt.Create;
  Result := globalVar;
end;
[edit]
Zitat:
Die Unit an Anfang der Uses-Klausel schreiben?
Klappt nicht zuverlässig, da sich hier die Reihenfolgen aller Uses-Klauseln des gesamten Projekts gegenseitig beeinflussen.

Nur bei den Uses in der DPR kann man sich relativ sicher sein, daß die erste Unit auch als erstes Initialisert wird (wenn man die Units SysInit und System ignoriert).
$2B or not $2B

Geändert von himitsu ( 8. Jun 2010 um 15:21 Uhr)
  Mit Zitat antworten Zitat
FriendOfDelphi

Registriert seit: 21. Mai 2010
163 Beiträge
 
Delphi 5 Professional
 
#4

AW: Zeitpunkt der Objekterstellung

  Alt 8. Jun 2010, 15:42
Bei Units, welche unter Interface eingebunden werden, wird die Initialisation immer vorher abgearbeitet, als die Initialisation der einbindenden Unit.

Bei Einbindung in der Implementation ist keine Reihenfolge sichergestellt.



Also entweder du greifst nur auf Units (und deren Inhalt) zu, welcher überimplementation eingebunden und rechtzeitig initialisiert werden.
Oder du prüfst beim Zugriff nach und verschiebst die Initialisation.

Letzeres z.B. so:
Delphi-Quellcode:
funktion gibObjekt: TObject;
begin
  if not assigned(globalVar) then
    globalVar := TMeinObjekt.Create;
  Result := globalVar;
end;
[edit]
Zitat:
Die Unit an Anfang der Uses-Klausel schreiben?
Klappt nicht zuverlässig, da sich hier die Reihenfolgen aller Uses-Klauseln des gesamten Projekts gegenseitig beeinflussen.

Nur bei den Uses in der DPR kann man sich relativ sicher sein, daß die erste Unit auch als erstes Initialisert wird (wenn man die Units SysInit und System ignoriert).
Ich habe das Einbinden der betreffenden Unit jetzt vom Bereich "Implementation" in den Bereich "Interface" verschoben.
Die Fehlermeldung kommt aber immer noch.
Herzlichen Gruß
FriendOfDelphi
  Mit Zitat antworten Zitat
FriendOfDelphi

Registriert seit: 21. Mai 2010
163 Beiträge
 
Delphi 5 Professional
 
#5

AW: Zeitpunkt der Objekterstellung

  Alt 8. Jun 2010, 15:54
Bei Units, welche unter Interface eingebunden werden, wird die Initialisation immer vorher abgearbeitet, als die Initialisation der einbindenden Unit.

Bei Einbindung in der Implementation ist keine Reihenfolge sichergestellt.



Also entweder du greifst nur auf Units (und deren Inhalt) zu, welcher überimplementation eingebunden und rechtzeitig initialisiert werden.
Oder du prüfst beim Zugriff nach und verschiebst die Initialisation.

Letzeres z.B. so:
Delphi-Quellcode:
funktion gibObjekt: TObject;
begin
  if not assigned(globalVar) then
    globalVar := TMeinObjekt.Create;
  Result := globalVar;
end;
[edit]
Zitat:
Die Unit an Anfang der Uses-Klausel schreiben?
Klappt nicht zuverlässig, da sich hier die Reihenfolgen aller Uses-Klauseln des gesamten Projekts gegenseitig beeinflussen.

Nur bei den Uses in der DPR kann man sich relativ sicher sein, daß die erste Unit auch als erstes Initialisert wird (wenn man die Units SysInit und System ignoriert).
Ich habe das Einbinden der betreffenden Unit jetzt vom Bereich "Implementation" in den Bereich "Interface" verschoben.
Die Fehlermeldung kommt aber immer noch.
Auch wenn vor dem Zugriff mit
Delphi-Quellcode:
if not assigned(Unit.Objekt) then
          Unit.Objekt:=TMeinObjekt.Create(self);
prüfe, kommt die Fehlermeldung (in der if-Zeile).
Herzlichen Gruß
FriendOfDelphi
  Mit Zitat antworten Zitat
Benutzerbild von Mithrandir
Mithrandir
(CodeLib-Manager)

Registriert seit: 27. Nov 2008
Ort: Delmenhorst
2.379 Beiträge
 
#6

AW: Zeitpunkt der Objekterstellung

  Alt 8. Jun 2010, 15:55
Bitte keine Fullquotes, wenn sie nicht nötig sind. Außerdem kannst du Beiträge editieren, Doppelpostings sind hier nicht gerne gesehen.
米斯蘭迪爾
"In einer Zeit universellen Betruges wird das Aussprechen der Wahrheit zu einem revolutionären Akt." -- 1984, George Orwell
  Mit Zitat antworten Zitat
FriendOfDelphi

Registriert seit: 21. Mai 2010
163 Beiträge
 
Delphi 5 Professional
 
#7

AW: Zeitpunkt der Objekterstellung

  Alt 8. Jun 2010, 17:17
Ich habe jetzt folgendes herausgefunden:
Das Formular der Unit, in welchem sich auch das Objekt befindet, ist bekannt. Ich kann z.B. mit FTest.Name:='xyz' den Namen ändern, ohne das ein Fehler auftritt.
Das Objekt darin ist (noch) nicht bekannt.
Es wird im FormCreate des Formulars erzeugt.
Muss die Erzeugung des Objekts vielleicht woanders erfolgen?
Gibt es eine andere Ereignis-Prozedur, die früher abgearbeitet wird?
Herzlichen Gruß
FriendOfDelphi
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.184 Beiträge
 
Delphi 12 Athens
 
#8

AW: Zeitpunkt der Objekterstellung

  Alt 8. Jun 2010, 17:28
"globale" Formulare, welche über die VCL (also automatisch) erzeugt werden,
werden erst erzeugt, nachdem alle Units unitialisiert wurden und mit der Abarbeitung der DPR begonnen wurde.

Heißt also, man kann nicht von irgendeinem Unit-Initialisierungsabschnitt auf ein solches Formular zugreifen, da es niemals existieren wird.



Es wäre also mal gut, wenn du genau erwähnst wie und von wo aus du auf dein Objekt/Formular zugreifst und wie/wo dieses Ogjekt/Formular erzeugt wird.
$2B or not $2B
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.625 Beiträge
 
Delphi 12 Athens
 
#9

AW: Zeitpunkt der Objekterstellung

  Alt 8. Jun 2010, 17:30
Ändere doch testhalber mal die Erstellungsreihenfolge der Units (in der Projektverwaltung Rechtsklick auf das Projekt - Quelltext anzeigen und das Application.CreateForm der entsprechenden Unit weiter nach oben setzen).
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
FriendOfDelphi

Registriert seit: 21. Mai 2010
163 Beiträge
 
Delphi 5 Professional
 
#10

AW: Zeitpunkt der Objekterstellung

  Alt 8. Jun 2010, 20:10
"globale" Formulare, welche über die VCL (also automatisch) erzeugt werden,
werden erst erzeugt, nachdem alle Units unitialisiert wurden und mit der Abarbeitung der DPR begonnen wurde.

Heißt also, man kann nicht von irgendeinem Unit-Initialisierungsabschnitt auf ein solches Formular zugreifen, da es niemals existieren wird.



Es wäre also mal gut, wenn du genau erwähnst wie und von wo aus du auf dein Objekt/Formular zugreifst und wie/wo dieses Ogjekt/Formular erzeugt wird.
Heißt das im Umkehrschluss das "nicht globale Formulare", die nicht über die VCL erzeugt werden, vorher abgearbeitet werden?
Ich habe nämlich in der betreffenden Unit ein Formular, das selbst nicht angezeigt wird; also leer ist.
Das ist nur noch da, weil ich darin mit procedure TFData.FormCreate(Sender: TObject); meinen Quellcode plaziert habe.
Kann ich darauf ganz verzichten?
Wenn ich kein Formular mehr habe, dann gibt es diese Prozedur und somit dessen Create ja auch nicht mehr.
Wo bringe ich denn dann meinen Quellcode unter, bzw. wie erreiche ich, dass dieser abgearbeitet wird?
Herzlichen Gruß
FriendOfDelphi
  Mit Zitat antworten Zitat
Antwort Antwort


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 20:03 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