AGB  ·  Datenschutz  ·  Impressum  







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

Problem mit 'nil' bei Objekten

Ein Thema von DSeven · begonnen am 18. Mär 2005 · letzter Beitrag vom 19. Mär 2005
Antwort Antwort
Seite 1 von 2  1 2      
DSeven

Registriert seit: 13. Aug 2003
114 Beiträge
 
#1

Problem mit 'nil' bei Objekten

  Alt 18. Mär 2005, 13:47
Hallo,

Ich habe folgendes etwas schwer zu beschreibendes Problem:
Undzwar habe ich mehrere Strategy's.
Über Strategy's kann man kurz gesagt funktionalität während der Laufzeit dynamisch ändern. Zum Beispiel Such algos.

Dieses Strategy's werden von IParserStrategy abgeleitet.
Ich füge die Strategy's dann in TList ein.
In meiner CodeBrowser Klasse habe ich eine Variable vom Typ IParserStrategy die immer die aktuelle Parser Strategy die verwendet werden soll aufnimmt.

Das problem liegt jetzt nur da, wenn eine Sprache z.B. SQL keinen Parser hat wird diese Variable auf nil gesetzt. Jetzt wird aber nicht nur die Variable auf nil gesetzt sondern auch das eigentliche IParserStrategy Objekt aus der TList. Es wird dann freigesetzt also der destrukor aufgerufen.

Wie kann ich das umgehen? In C++ ist das ja nicht so.
Falls ich es zu schwer erklärt habe bitte nochmal fragen.

cya
Die Freie Entwicklungsumgebung für PHP
Symtec Development Studio
auf http://www.nostalb.de
  Mit Zitat antworten Zitat
Benutzerbild von Kedariodakon
Kedariodakon

Registriert seit: 10. Sep 2004
Ort: Mönchengladbach
833 Beiträge
 
Delphi 7 Enterprise
 
#2

Re: Problem mit 'nil' bei Objekten

  Alt 18. Mär 2005, 14:29

Erstellst du für jeden TList Eintrag einen neuen "Strategy's" oder benutzt du immer den selben???
Wenn du für jeden einen erstellst fügst du bestimmt so die sachen ein: addObject('222433254', @"Strategy's" ); richtig?
Wenn das so ist, lösch mal das "@"...

Wenn das jetzt alles müll war, da ichs net verstanden hab, was du tust, einfach ignorieren

Bye
Christian
  Mit Zitat antworten Zitat
DSeven

Registriert seit: 13. Aug 2003
114 Beiträge
 
#3

Re: Problem mit 'nil' bei Objekten

  Alt 18. Mär 2005, 18:41
Em also ich füge zum Beispiel vier verschiedene IParserStrategy's ein. Und eigentlich wird immer das richtige Strategy ausgewählt. Aber wenn eine Sprache keins hat dann wird das vorherige Strategy einfach freigesetzt.

Strategy's werden in software Design Büchern gut erklärt. Also auf jeden fall einen blick wert.
Da Klassen und interfaces immer pointer sind ist

addObject('222433254', @Strategy );

equvalent zu

addObject('222433254', ParserStrategy);

Beides Zeiger beim ersten wird die Adresse übergeben und beim zweiten der Zeiger.
Bor Delphi ist ja schwerer als C++ warum wird es nicht wie in C++ gelöst.

cya
Die Freie Entwicklungsumgebung für PHP
Symtec Development Studio
auf http://www.nostalb.de
  Mit Zitat antworten Zitat
Benutzerbild von mirage228
mirage228

Registriert seit: 23. Mär 2003
Ort: Münster
3.750 Beiträge
 
Delphi 2010 Professional
 
#4

Re: Problem mit 'nil' bei Objekten

  Alt 18. Mär 2005, 19:00
Hi,

wenn Du einem Interface nil zuweist, wird (in Delphi) imho automatisch der Destruktor aufgerufen.

Ich würde Dir ansonsten noch empfehlen eine TInterfaceList zu verwenden, wenn Du mehrere Interfaces verwalten willst. Denn dazu ist diese gedacht.

mfG
mirage228
David F.

May the source be with you, stranger.
PHP Inspection Unit (Delphi-Unit zum Analysieren von PHP Code)
  Mit Zitat antworten Zitat
DSeven

Registriert seit: 13. Aug 2003
114 Beiträge
 
#5

Re: Problem mit 'nil' bei Objekten

  Alt 18. Mär 2005, 19:15
Zitat von mirage228:
Hi,

wenn Du einem Interface nil zuweist, wird (in Delphi) imho automatisch der Destruktor aufgerufen.

mfG
mirage228
Jup ich weis deswegen frag ich ja nach einem lösungs ansatz.
Das nervt mich auch an delphi, warum wird es nicht so wie in c++ gemacht?



Zitat von mirage228:
Ich würde Dir ansonsten noch empfehlen eine TInterfaceList zu verwenden, wenn Du mehrere Interfaces verwalten willst. Denn dazu ist diese gedacht.
Hehe stimmt
Wieso funktioniert es jetzt auf einmal? Also jetzt gibts kein Problem wenn ich das Teil auf nil setzte das orignal in der Liste bleibt unbetroffen.
Würde nur zu gerne wissen warum? Schließlich will man auch die hintergründe verstehen.
Die Freie Entwicklungsumgebung für PHP
Symtec Development Studio
auf http://www.nostalb.de
  Mit Zitat antworten Zitat
Benutzerbild von mirage228
mirage228

Registriert seit: 23. Mär 2003
Ort: Münster
3.750 Beiträge
 
Delphi 2010 Professional
 
#6

Re: Problem mit 'nil' bei Objekten

  Alt 18. Mär 2005, 19:25
Hi,

also genau weiss ich das auch nicht.
Aber ich vermute, dass TInterfaceList die Referenzzählung handhabt, sodass das enstprechende Interface beim NIL setzen nicht freigegeben wird.

Aber mehr weiss ich auch nicht, habe mich noch nicht mit TInterfaceList beschäftigt

mfG
mirage228
David F.

May the source be with you, stranger.
PHP Inspection Unit (Delphi-Unit zum Analysieren von PHP Code)
  Mit Zitat antworten Zitat
Benutzerbild von maximov
maximov

Registriert seit: 2. Okt 2003
Ort: Hamburg
548 Beiträge
 
Delphi 2005 Professional
 
#7

Re: Problem mit 'nil' bei Objekten

  Alt 18. Mär 2005, 19:27
Zitat von DSeven:
....Hehe stimmt
Wieso funktioniert es jetzt auf einmal? Also jetzt gibts kein Problem wenn ich das Teil auf nil setzte das orignal in der Liste bleibt unbetroffen.
Würde nur zu gerne wissen warum? Schließlich will man auch die hintergründe verstehen.
Naja, in delphi haben interfaces COM-pflicht und COM hat nunmal einen referenzCounter-muster (_AddRef und _Release). Wenn du deine strategie in eine normale liste einfügst, so passiert nix, bei einer intergefacesten liste wird _addRef aufgerufen und somit mitgeteilt, das noch eine referenz besteht, was dazu führt, das das objekt noch nicht freigegeben wird
mâxîmôv.

{KDT}
  Mit Zitat antworten Zitat
Robert_G
(Gast)

n/a Beiträge
 
#8

Re: Problem mit 'nil' bei Objekten

  Alt 19. Mär 2005, 00:11
Du kannst auch anstatt von TInterfacedObject abzuleiten, deine eigene Basisklasse entwickeln.
Den Krampf hatte ich mir mal angetan, da ich meinen Code nicht mit AddRefs zumüllen wollte. Auf die Art liegt es bei dir wann die Instanz zerstört wird.
  Mit Zitat antworten Zitat
bttb930

Registriert seit: 6. Okt 2003
372 Beiträge
 
#9

Re: Problem mit 'nil' bei Objekten

  Alt 19. Mär 2005, 03:04
schau dir einfach mal die _AddRef- und _Release-Funktionen der Basisklassen an, dann dürftest Du das ganze leicht verstehen (Unit System):

Delphi-Quellcode:
function TInterfacedObject._AddRef: Integer;
begin
  Result := InterlockedIncrement(FRefCount);
end;

function TInterfacedObject._Release: Integer;
begin
  Result := InterlockedDecrement(FRefCount);
  if Result = 0 then
    Destroy;
end;
_Release ruft halt den Destruktor auf, wenn der interne Zähler 0 ist. Das ist fatal, weil das in vielen Fällen nicht heißt, dass das Objekt nicht mehr referenziert wird.

Man kann das umgehen, indem man eine eigene Klasse von TInterfacedObject ableitet und _Release überschreibt.
  Mit Zitat antworten Zitat
NicoDE
(Gast)

n/a Beiträge
 
#10

Re: Problem mit 'nil' bei Objekten

  Alt 19. Mär 2005, 08:12
Wenn man weiss was man tut, kann man auch
Code:
Pointer(Foo) := nil;
verwenden.

(sollte man aber im Quelltext kommentieren, da man schnell wieder vergisst, warum man solche Hacks mal eben eingebaut hat... und meist gibt es eine saubere Lösung (nur halt nicht immer *g*)).

Zitat von DSeven:
Das nervt mich auch an delphi, warum wird es nicht so wie in c++ gemacht?
Weil es ziemlich nervt sich manuell um den Referenzzähler kümmern zu müssen.
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


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 03:34 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