AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Sprachen und Entwicklungsumgebungen Object-Pascal / Delphi-Language Delphi Zugriffsverletzung mit Interfaces und TList-Nachfahre
Thema durchsuchen
Ansicht
Themen-Optionen

Zugriffsverletzung mit Interfaces und TList-Nachfahre

Ein Thema von FAlter · begonnen am 16. Jan 2009 · letzter Beitrag vom 17. Jan 2009
Antwort Antwort
Benutzerbild von FAlter
FAlter

Registriert seit: 21. Jul 2004
Ort: Ostfildern
1.096 Beiträge
 
FreePascal / Lazarus
 
#1

Zugriffsverletzung mit Interfaces und TList-Nachfahre

  Alt 16. Jan 2009, 21:57
Hi,

Codeausschnitt:

Delphi-Quellcode:
  SimpleBrain := TSimpleBrain.Create(1, 1);
  try
    try
      //kleiner Hack zum Testen --> Programmierung dass
      with TNeuron(SimpleBrain.Input[0]) do
      begin
        Output.Add(SimpleBrain.Output[0]);
in der letzten geposteten Zeile kommt es zur AV, wobei nicht einmal die Add-Methode betreten wird, das heißt vermutlich knallt es schon vorher beim Zugriff auf Input[0].Output, weil Input nicht mehr existiert.

SimpleBrain.Input/Output sind Eigenschaften vom Typ TNeuronList, diese gibt ein INeuron-Interface zurück. Ich weiß aber (da es mein Code ist), dass dahinter die Klasse TNeuron steckt, und auf eine Eigenschaft von dieser, die wiederum eine TNeuronList ist, möchte ich (testweise) zugreifen.

Im Debugger wird bei F7 drücken nie durch den Destruktor von TNeuron gegangen, das hatte ich anfangs, da ich durch die Typecasts die Referenzzählöungs-CompilerMagic ausgehebelt habe, aber nun habe ich manuell _AddRef und _Release aufgerufen, und ich lande auch nicht mehr im Destruktor. Mein Neuron sollte also noch existieren.

Nun ja, ich finde die Ursache nicht.

Im Anhang das komplette Programm.

Mfg
FAlter
Angehängte Dateien
Dateityp: zip brain090116_2153_648.zip (4,6 KB, 0x aufgerufen)
Felix Alter
  Mit Zitat antworten Zitat
Apollonius

Registriert seit: 16. Apr 2007
2.325 Beiträge
 
Turbo Delphi für Win32
 
#2

Re: Zugriffsverletzung mit Interfaces und TList-Nachfahre

  Alt 16. Jan 2009, 22:09
Im Gegensatz zu Klassen im Falle der Einfachvererbung verschiebt sich bei Interface-Casts der Wert deines Zeigers, d.h. Inst as IInterface <> Inst. Deshalb gibt es keine einfache Möglichkeit, vom Interface zurück auf die Objekt-Instanz zu kommen. Wenn du es unbedingt haben willst: klick Allerdings stellt sich dann die Frage, ob du nicht lieber im Interface alles veröffentlichen solltest, was auch in TNeuron ist. Außerdem solltest du dir überlegen, eine TInterfaceList zu verwenden, damit du die Referenzzählung nicht von Hand austricksen musst.
Wer erweist der Welt einen Dienst und findet ein gutes Synonym für "Pointer"?
"An interface pointer is a pointer to a pointer. This pointer points to an array of pointers, each of which points to an interface function."
  Mit Zitat antworten Zitat
Benutzerbild von FAlter
FAlter

Registriert seit: 21. Jul 2004
Ort: Ostfildern
1.096 Beiträge
 
FreePascal / Lazarus
 
#3

Re: Zugriffsverletzung mit Interfaces und TList-Nachfahre

  Alt 16. Jan 2009, 22:22
Hi,

dass sich die Adressen verschieben wusste ich nicht, aber wenn das so ist, gibt es eine logische Erklärung dazu.

Die TInterfacedList kannte ich noch gar nicht... werds auf die umstellen.

Das Problem mit dem im Interface veröffentlichen ist dass dann die Interface-Unit die Listen-Unit im interface-Abschnitt kennen müsste, und umgekehrt sowieso, und das geht leider nicht. Aber ich könnte notfalls TInterfacedList zurückgeben und diese auf meine Klasse Casten, dann habe ich ja wieder Klasse-->Klasse gecastet. Quatsch, dann kom ich ja wieder nur auf ein Interface. Muss wohl ne _GetObject implementieren wi sich das Objekt dann selbst zurückliefert.

Warum gibt der Compiler keine Warnung beim Cast Interface-->Klasse?

Mfg
FAlter
Felix Alter
  Mit Zitat antworten Zitat
Apollonius

Registriert seit: 16. Apr 2007
2.325 Beiträge
 
Turbo Delphi für Win32
 
#4

Re: Zugriffsverletzung mit Interfaces und TList-Nachfahre

  Alt 16. Jan 2009, 22:28
Weil du mit dem harten Cast sagst, dass du weißt, was du tust. Wenn du stattdessen versucht hättest, einen as-Cast durchzuführen, hättest du den Fehler "Operand not applicable to this operand type" erhalten.
Wer erweist der Welt einen Dienst und findet ein gutes Synonym für "Pointer"?
"An interface pointer is a pointer to a pointer. This pointer points to an array of pointers, each of which points to an interface function."
  Mit Zitat antworten Zitat
Benutzerbild von FAlter
FAlter

Registriert seit: 21. Jul 2004
Ort: Ostfildern
1.096 Beiträge
 
FreePascal / Lazarus
 
#5

Re: Zugriffsverletzung mit Interfaces und TList-Nachfahre

  Alt 16. Jan 2009, 22:43
Hi,

ich glaubte ja auch zu wissen was ich tue. Es sollte ja eh nur ein Test sein, denn mein SimpleBrain kann ja noch nicht lernen, und ich wollte trotzdem schonmal testen ob die Neuronen arbeiten.
Das Java, mit dem ich derzeit beruflich arbeite, schmeißt bei (blubb)wuppdi auch immer Warnungen raus... idt aber auch kein schickes Delphi.

Naja, Hauptsache ich kann jetzt weitertesten, auch wenn es nicht an die Intelligenz eines Regenwurms heranreichen wird... Vielleicht krieg ich es ja wirklich hin was lernendes zu programmieren.

Mfg
FAlter
Felix Alter
  Mit Zitat antworten Zitat
Benutzerbild von Bernhard Geyer
Bernhard Geyer

Registriert seit: 13. Aug 2002
17.202 Beiträge
 
Delphi 10.4 Sydney
 
#6

Re: Zugriffsverletzung mit Interfaces und TList-Nachfahre

  Alt 17. Jan 2009, 09:23
Zitat von FAlter:
... , schmeißt bei (blubb)wuppdi auch immer Warnungen raus...
AFAIK ist bei Java (wie unter .NET) eh kein harter Cast möglich. Das obige beispiel entspricht dem "as"-Cast in Delphi.
Windows Vista - Eine neue Erfahrung in Fehlern.
  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 06:55 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 by Thomas Breitkreuz