AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Algorithmen, Datenstrukturen und Klassendesign Delphi Objekt als Rückgabe von Funktion - Wie elegant Freigabe regeln?
Thema durchsuchen
Ansicht
Themen-Optionen

Objekt als Rückgabe von Funktion - Wie elegant Freigabe regeln?

Ein Thema von Zacherl · begonnen am 22. Aug 2013 · letzter Beitrag vom 25. Aug 2013
Antwort Antwort
Seite 1 von 3  1 23      
Benutzerbild von Zacherl
Zacherl

Registriert seit: 3. Sep 2004
4.629 Beiträge
 
Delphi 10.2 Tokyo Starter
 
#1

Objekt als Rückgabe von Funktion - Wie elegant Freigabe regeln?

  Alt 22. Aug 2013, 23:22
Hallo zusammen,

ich habe eine Funktion, welche ein Objekt erstellt, welches im weiteren Verlauf für eine unbestimmte Zeit innerhalb eines zweiten Threads verwendet wird. Die Funktion liefert das Objekt zusätzlich als Rückgabewert an den aufrufenden Benutzer zurück, damit dieser bestimmte Informationen (die der Thread setzt) mitverfolgen und auch per Methodenaufruf z.B. die Verarbeitung abbrechen kann.

Das Problem besteht nun in der Frage, wer das Objekt wieder freigeben soll. Geschieht dies nach seiner Verarbeitung im Thread, kann es sein, dass der Benutzer nachträglich versucht auf das nicht mehr existierende Objekt zuzugreifen. Gibt der Benutzer das Objekt frei, hat man das selbe Problem in umgekehrter Richtung.

Folgende Möglichkeiten sind mir eingefallen:
  • Ich gebe ein Interface zurück, welches von Delphi automatisch über _Release() freigegeben wird, sobald keine Referenz mehr existiert
  • Ich gebe in der Funktion ein Wrapper Objekt zurück, welches nach Art des Proxy Patterns auf das eigentliche Datenobjekt zugreift. Der Thread würde dann bei Freigabe des Datenobjekts auch ein Flag im Wrapper Objekt setzen, was dafür sorgt, dass der Benutzer nicht mehr auf bestimmte Werte und Methoden zugreifen kann

Welche dieser Methoden würdet ihr bevorzugen oder fällt euch vielleicht noch eine bessere Alternative ein?

Viele Grüße
Zacherl
Projekte:
- GitHub (Profil, zyantific)
- zYan Disassembler Engine ( Zydis Online, Zydis GitHub)
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

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

AW: Objekt als Rückgabe von Funktion - Wie elegant Freigabe regeln?

  Alt 23. Aug 2013, 08:12
Ist es denn unbedingt notwendig, dass die Funktion das Objekt erstellt? Ich tendiere eigentlich immer dazu, das Objekt außerhalb zu erstellen und dann als Parameter an die Routine zu übergeben, damit stellt sich das Problem erst gar nicht.
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
Blup

Registriert seit: 7. Aug 2008
Ort: Brandenburg
1.464 Beiträge
 
Delphi 12 Athens
 
#3

AW: Objekt als Rückgabe von Funktion - Wie elegant Freigabe regeln?

  Alt 23. Aug 2013, 08:31
Interface deckt den Fall optimal ab, warum dann etwas neues erfinden.
  Mit Zitat antworten Zitat
Lemmy

Registriert seit: 8. Jun 2002
Ort: Berglen
2.380 Beiträge
 
Delphi 10.3 Rio
 
#4

AW: Objekt als Rückgabe von Funktion - Wie elegant Freigabe regeln?

  Alt 23. Aug 2013, 08:58
Guten Morgen,

Instanz außerhalb erstellen (wer erstellt gibt frei) oder Interface verwenden, was wegen der geringeren Kopplung der Teile aber wohl der bessere Ansatz wäre.
  Mit Zitat antworten Zitat
Mikkey

Registriert seit: 5. Aug 2013
265 Beiträge
 
#5

AW: Objekt als Rückgabe von Funktion - Wie elegant Freigabe regeln?

  Alt 23. Aug 2013, 09:52
Dass die Funktion hier das Objekt erstellt und zurückgibt, hat mMn mit der Problematik nichts zu tun.

Denkbar sind für die Freigabe beide Varianten, bei der zweiten sehe ich nur einen einigermaßen unüberschaubaren Verwaltungsaufwand und das Problem, dem Benutzer das ulkige Verhalten des Programms zu erklären.

Also ganz klar 1. Variante: wenn zwei oder mehr Threads das Objekt verwenden, darf es erst freigegeben werden, wenn der letzte damit fertig ist.
  Mit Zitat antworten Zitat
mentaltec

Registriert seit: 28. Sep 2012
60 Beiträge
 
#6

AW: Objekt als Rückgabe von Funktion - Wie elegant Freigabe regeln?

  Alt 23. Aug 2013, 10:37
TObject mit Ref-Counter versehen, in einer Class TObjList merken
das Destroy dect den Refcounter und greift erst, wenn Refcounter == 0

oder so ähnlich, mfg
  Mit Zitat antworten Zitat
Benutzerbild von Zacherl
Zacherl

Registriert seit: 3. Sep 2004
4.629 Beiträge
 
Delphi 10.2 Tokyo Starter
 
#7

AW: Objekt als Rückgabe von Funktion - Wie elegant Freigabe regeln?

  Alt 23. Aug 2013, 16:31
Ist es denn unbedingt notwendig, dass die Funktion das Objekt erstellt? Ich tendiere eigentlich immer dazu, das Objekt außerhalb zu erstellen und dann als Parameter an die Routine zu übergeben, damit stellt sich das Problem erst gar nicht.
In meinem Falle schon, da das Objekt innerhalb eines Threads verarbeitet wird. Ich kann die Instanz also nicht direkt nach Funktionsaufruf wieder freigeben.

Dann werde ich es mal mit der Interface Methode probieren. Dachte mir schon, dass dies die einfachste Lösung ist.

Danke an alle!
Projekte:
- GitHub (Profil, zyantific)
- zYan Disassembler Engine ( Zydis Online, Zydis GitHub)
  Mit Zitat antworten Zitat
Furtbichler
(Gast)

n/a Beiträge
 
#8

AW: Objekt als Rückgabe von Funktion - Wie elegant Freigabe regeln?

  Alt 23. Aug 2013, 18:00
In meinem Falle schon, da das Objekt innerhalb eines Threads verarbeitet wird. Ich kann die Instanz also nicht direkt nach Funktionsaufruf wieder freigeben.
Sollst Du ja nicht
Entweder ...
a)... die Architektur leicht abändern, um dem Paradigma: "Wer Dreck macht, räumt auch auf" gerecht zu werden, oder
b)... das Objekt einfach als Letztes im "Execute" freigeben oder
c)... das Objekt vom Threadersteller freigeben, sobald der Thread 'Fertig' meldet oder
d)... das Objekt gar nicht bzw. zum Programmende freigeben (wenn das sinnvoll ist)

Ich persönlich würde a) prüfen und wenn das nicht passt, c) umsetzen, da dann die Freigabe im Context des Objekterstellers geschieht.
  Mit Zitat antworten Zitat
Benutzerbild von Zacherl
Zacherl

Registriert seit: 3. Sep 2004
4.629 Beiträge
 
Delphi 10.2 Tokyo Starter
 
#9

AW: Objekt als Rückgabe von Funktion - Wie elegant Freigabe regeln?

  Alt 24. Aug 2013, 16:59
Das ist alles leider nicht optimal. Ich versuche mal mein Problem etwas detaillierter darzustellen:
Ich habe einen Thread, welcher permanent von Programmstart bis zum Programmende läuft. Der Thread wartet im Hintergrund darauf, bis er einen oder mehrere Tasks zugewiesen bekommt und arbeitet diese dann ab. Die Tasks habe ich in einer Klasse gekapselt, welche einige Attribute wie z.b. den Progress und einige Methoden z.b. zum Abbrechen des Tasks besitzt.
Das Erstellen des Tasks passiert in der von mir genannten Funktion, welche das Objekt dann intern an den Thread weitergibt und zusätzlich dem aufrufenden Benutzer als Rückgabe liefert, damit man beispielsweise den Status des Tasks in einer Liste anzeigen lassen kann.

(a) scheidet für mich daher aus, weil ich nicht ohne Weiteres sagen kann, wer zuletzt auf das Objekt zugreift. Wenn ich es im Thread freigebe, könnte es sein, dass danach noch ein Zugriff von "außerhalb" erfolgt z.b. um die Daten in der Liste zu aktualiseren. Wenn ich es von Benutzerseite aus freigebe, könnte es passieren, dass der Thread noch nicht mit der Verarbeitung fertig ist.
(b) funktioniert in meinem Falle auch nicht, da der Thread ja zur kompletten Laufzeit des Programms aktiv ist
(d) hier würde mir recht schnell der Speicher vollaufen, da doch eine ganze Menge an Tasks verarbeitet werden

(c) würde funktionieren, allerdings ist das auch nicht wirklich "intuitiv" für den Anwender (Programmierer). Da müsste man in der Dokumentation ziemlich deutlich drauf hinweisen, dass die Freigabe des Objekts wirklich erst im entsprechenden Callback erfolgen darf und nicht direkt nach Funktionsaufruf.

Bin mir momentan unsicher, ob ich Methode (c) implementieren, oder es mit den Interfaces versuchen soll. Letztere haben allerdings auch gewisse Nachteile. Z.b. müsste ich dann auch in allen Callbacks das Interface anstelle des Objekts übergeben und auch hier in der Doku den Hinweis platzieren, dass die Instanz nur als Interface und nicht als konkretes Objekt gespeichert werden darf (weil sonst ja der Ref Counter Mechanismus nicht mehr greift), etc.
Projekte:
- GitHub (Profil, zyantific)
- zYan Disassembler Engine ( Zydis Online, Zydis GitHub)
  Mit Zitat antworten Zitat
Thom

Registriert seit: 19. Mai 2006
570 Beiträge
 
Delphi XE3 Professional
 
#10

AW: Objekt als Rückgabe von Funktion - Wie elegant Freigabe regeln?

  Alt 24. Aug 2013, 17:15
[...] dass die Instanz nur als Interface und nicht als konkretes Objekt gespeichert werden darf [...]
Das kannst Du recht effektiv verhindern, indem Du den Objektkonstruktor durch eine Klassenfunktion verdeckst:
Delphi-Quellcode:
class function Create: IMyInterface;
[...]
Damit bekommt niemand mehr Zugriff auf die eigentliche Objektinstanz (außer bei einem Cast IInterface as TObject ) und damit den Destruktor.
Thomas Nitzschke
Google Maps mit Delphi
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 3  1 23      


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 14:47 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