AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Algorithmen, Datenstrukturen und Klassendesign Packed record mit Dictionary als Variable, Richtig aufräumen
Thema durchsuchen
Ansicht
Themen-Optionen

Packed record mit Dictionary als Variable, Richtig aufräumen

Ein Thema von SusiT · begonnen am 15. Jan 2024 · letzter Beitrag vom 16. Jan 2024
Antwort Antwort
Seite 1 von 2  1 2      
SusiT

Registriert seit: 15. Mai 2014
40 Beiträge
 
#1

Packed record mit Dictionary als Variable, Richtig aufräumen

  Alt 15. Jan 2024, 22:52
Guten Abend,

ich habe einen packed Record mit einem Dictionary als Variable angelegt.

Delphi-Quellcode:
TCurrActivity = packed record
 ActId : Integer;
 NsRelatedRowsIds : TDictionary<String,Integer>;
 procedure init;
 procedure clear;
end;

Beim Erstellen wird init und beim aufräumen wird clear aufgerufen.

Delphi-Quellcode:
procedure TCurrActivity.init;
begin
   ActId := 0;
   Self.NsRelatedRowsIds := TDictionary<String,Integer>.Create;
end;

procedure TCurrActivity.clear;
begin
 self := default(TCurrActivity);
end;
Mir erschließt sich gerade nicht wie die richtige Herangehensweise ist um das Dictionary richtig aufzuräumen, sobald das Packed Record freigegeben wird.

Normalerweise mache ich

Delphi-Quellcode:
NsRelatedRowsIds.Clear;
FreeAndNil(NsRelatedRowsIds);
um nach getaner Arbeit den Speicher eines Dicts wieder freizugeben.

Wie verhält sich das, wenn ich das Dict in einem packed record verschachtelt ist?

Am liebsten würde ich folgendes machen:

Delphi-Quellcode:
procedure TCurrActivity.clear;
begin
// Self.NsRelatedRowsIds.Clear;
// FreeAndNil(Self.NsRelatedRowsIds);

 self := default(TCurrActivity);

 Self.NsRelatedRowsIds.Clear;
 FreeAndNil(Self.NsRelatedRowsIds);
end;
um das Dict im packed record richtig aufzuräumen, allerdings
gibt dies Zugriffsverletzungen.

Daher die Frage muss ich ein Dict welches in einem packed record Created ist auch wieder freigeben oder ist dies egal?
Macht das ganze Konstrukt bzw. die Idee überhaupt Sinn bzw ist so umsetzbar?


Vielen Dank und viele Grüße
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

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

AW: Packed record mit Dictionary als Variable, Richtig aufräumen

  Alt 16. Jan 2024, 03:49
:= Default(...) überschreibt einfach alles mit Nullen.
Von den Zeiger-Typen werden ausschließlich Managed-Typen automatisch freigegeben. (Variant, LongStrings, Interfaces und dynamische Arrays)
Also erst das Objekt freigeben und danach den Record leeren.

mögliche Lösungen
* Object anstatt Record
* Interface statt Object
* dynamisches Array anstatt Liste/Dictionary (mit dem generischen TArray.BinarySearch kann man es wie eine sortierte Liste behandeln -> Suchen, sowie für's Insert)
* Bei Google suchenCustom Managed Records
* ...

https://blogs.embarcadero.com/custom...o-delphi-10-4/
https://docwiki.embarcadero.com/RADS...anaged_Records
$2B or not $2B
  Mit Zitat antworten Zitat
Der schöne Günther

Registriert seit: 6. Mär 2013
6.181 Beiträge
 
Delphi 10 Seattle Enterprise
 
#3

AW: Packed record mit Dictionary als Variable, Richtig aufräumen

  Alt 16. Jan 2024, 09:42
Wie schon gesagt, du musst das Dictionary explizit freigeben, sonst verbleibt es auf ewig im Speicher. Oder du stellst es auf einen Interface-Typ um, dann brauchst du dich darum nicht mehr kümmern.

Ob der record packed ist oder nicht ist hier eigentlich völlig egal.
  Mit Zitat antworten Zitat
SusiT

Registriert seit: 15. Mai 2014
40 Beiträge
 
#4

AW: Packed record mit Dictionary als Variable, Richtig aufräumen

  Alt 16. Jan 2024, 09:43
Habe ich verstanden, vielen Dank.

Ich nutze die packed records sehr gerne, da diese sich recht leicht erstellen und verwalten lassen.

Grundsätzlich ist es aber möglich, dass komplexere Speicherstrukturen in einem packed record enthalten sind nehme ich an? (Wie zb. Dictionarys)

Ohne das irgendwelche komischen Sachen passieren


Viele Grüße
  Mit Zitat antworten Zitat
Der schöne Günther

Registriert seit: 6. Mär 2013
6.181 Beiträge
 
Delphi 10 Seattle Enterprise
 
#5

AW: Packed record mit Dictionary als Variable, Richtig aufräumen

  Alt 16. Jan 2024, 10:13
Ein TDictionary ist an sich nicht komplex, das ist ja nur ein "Zeiger" auf einen Bereich anderswo, außerhalb des Records. Eben deshalb musst du das Dictionary explizit wieder freigeben.

Es gibt noch Typen bei denen der Compiler (bzw. die automatische Referenzzählung "ARC") sich darum kümmert, den Speicher wieder freizugeben. Das ist beispielsweise der Fall bei Strings, oder dynamischen Arrays. Da musst du dich auch nicht drum kümmern. Würdest du ein für dich passendes Interface um dein TDictionary basteln und dann ein IDictionary verwenden, müsstest du dich um die Freigabe auch nicht mehr kümmern 😊


Meine Frage wäre noch, weshalb das packed ? Bist du dir sicher, dass du das brauchst? Ich kenne das eigentlich nur, wenn du eine Struktur 1:1 serialisieren willst (z.B. für Netzwerk-Übertragung oder Speichern in eine Datei), aber das kann man sich eh schenken wenn du zeigerbasierte Typen (wie z.B. ein Dictionary) drin hast.

packed macht den Speicherzugriff auf Teile des Records nur langsamer, weil verhindert wird, dass (für dich unsichtbare) Lücken zwischen den Feldern des Records gepackt werden, damit der Computer für ihn besser den Speicher da rauslesen kann.
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

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

AW: Packed record mit Dictionary als Variable, Richtig aufräumen

  Alt 16. Jan 2024, 10:43
Ich nutze die packed records sehr gerne, da diese sich recht leicht erstellen und verwalten lassen.
Das hat aber nichts mit Packed zu tun.

So lange es nicht auf jedes einzelne Byte drauf an kommt oder der Record für Speicherung oder Datenübertragung (in andere Systeme/Programme/...) verwendet wird, kann es aber nachteile bringen, wenn Speicher ungünstig ausgerichtet ist.
$2B or not $2B
  Mit Zitat antworten Zitat
Andreas13

Registriert seit: 14. Okt 2006
Ort: Nürnberg
720 Beiträge
 
Delphi XE5 Professional
 
#7

AW: Packed record mit Dictionary als Variable, Richtig aufräumen

  Alt 16. Jan 2024, 10:53
... Also erst das Objekt freigeben und danach den Record leeren....
Das verstehe ich nicht ganz... Sollte die Reihenfolge nicht anders sein?
Grüße, Andreas
Wenn man seinem Nächsten einen steilen Berg hinaufhilft, kommt man selbst dem Gipfel näher. (John C. Cornelius)
  Mit Zitat antworten Zitat
TBx
(Administrator)

Registriert seit: 13. Jul 2005
Ort: Stadthagen
1.894 Beiträge
 
Delphi 12 Athens
 
#8

AW: Packed record mit Dictionary als Variable, Richtig aufräumen

  Alt 16. Jan 2024, 11:17
... Also erst das Objekt freigeben und danach den Record leeren....
Das verstehe ich nicht ganz... Sollte die Reihenfolge nicht anders sein?
Nein, das Leben des Records wird durch Überschreiben mit Nullwerten realisiert. Damit würde mann auch den Zeiger überschreiben, der zum Löschen des Objektes benötigt wird.
Thomas Breitkreuz
Gruß Thomas
- Admin DelphiPRAXIS
- Admin Delphi-Treff
- Embarcadero MVP
  Mit Zitat antworten Zitat
Andreas13

Registriert seit: 14. Okt 2006
Ort: Nürnberg
720 Beiträge
 
Delphi XE5 Professional
 
#9

AW: Packed record mit Dictionary als Variable, Richtig aufräumen

  Alt 16. Jan 2024, 11:24
Danke, jetzt habe ich das verstanden!
Grüße, Andreas
Wenn man seinem Nächsten einen steilen Berg hinaufhilft, kommt man selbst dem Gipfel näher. (John C. Cornelius)
  Mit Zitat antworten Zitat
Benutzerbild von jaenicke
jaenicke
Online

Registriert seit: 10. Jun 2003
Ort: Berlin
9.716 Beiträge
 
Delphi 11 Alexandria
 
#10

AW: Packed record mit Dictionary als Variable, Richtig aufräumen

  Alt 16. Jan 2024, 13:52
Daher die Frage muss ich ein Dict welches in einem packed record Created ist auch wieder freigeben oder ist dies egal?
Macht das ganze Konstrukt bzw. die Idee überhaupt Sinn bzw ist so umsetzbar?
Technisch bekommt man das zwar hin, aber ich halte es für keine saubere Lösung, wenn man manuell verwaltete Elemente wie Klassen in automatisch verwaltete Records packt. Umgekehrt ist das kein Problem, aber in der Richtung muss man immer aufpassen, dass man keinen Fehler macht.

Ein Problem ist z.B., dass ein Record beim Zugriff ggf. komplett kopiert wird, z.B. beim Abrufen aus einer Liste. Und schon hat man den Record zweimal im Speicher mit der gleichen einmal erzeugten Liste. Bei einer Klasse hast du dann nur zwei Referenzen auf den gleichen Speicher.

Insgesamt machst du dir das Leben an der Stelle deutlich einfacher, wenn du Klassen verwendest. Dort erzeugst du die Liste im Konstruktor und gibst sie im Destruktor frei. Dass das mit Records mittlerweile auch geht (Custom Managed Records), ist schon richtig, aber das ist dann nicht einfacher als mit Klassen, sondern an einigen Stellen ein großer Nachteil, und außerdem macht man leichter Fehler dabei.

Der einzige echte Vorteil von Records ist, dass bei massenhafter Verwendung (viele zehntausend z.B.) die Performance und die Speicherbelastung besser sind. Das macht sich aber wirklich erst bei sehr sehr vielen Records bemerkbar. Abgesehen von solchen Optimierungsproblemen überwiegen die Nachteile von Records gegenüber Klassen.
Sebastian Jänicke
AppCentral
  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 01:01 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