![]() |
Re: Speicherbereinigung von Strings
:shock: Mach das bloß nicht. Niemand garantiert dir das es in der nächsten Delphiversion noch genau so ist und dann kannst du dein Projekt weg werfen.
Alle Variablen die du definierst werden innerhalb eines gewissen Bereiches desfiniert (lokal, global, membervariable). Sobald diese Bereiche verlassen werden verlieren auch die Variablen ihre Gültigkeit. Wenn du also bei verlassen der Bereiche die Werte hinter den Variablen nicht verlieren willst, musst du wie bereits gezeigt den Speicher explizit anfordern. Nur explizit angeforderter Speicher wird auch erst frei gegeben wenn er explizit freigegeben wird. Wenn Speicher automatisch reserviert wird durch declaration in einem Gültigkeitsbereich wird er auch automatisch frei gegeben. Mach dir am besten eine schöne Klasse oder ein dynamisches Array wenn du mit Klassen nicht so fit bist. Irgendwo im Speicher rum schreiben und darauf verlassen das sich die Struktur nie ändert ist der falsche Ansatz. |
Re: Speicherbereinigung von Strings
Ergänzung: Du musst noch aufpassen, dass der Referenzzähler <> -1 ist, dann nicht verändern.
oder so
Delphi-Quellcode:
asm
mov eax,your_ansi_string call system.@lstraddref end; @sir: Solange man das kann, ist es mit Abstand der bessere Weg. Abgesehen davon bin ich bei Strings mit Kombatibilitätsaussagen sowieso etwas vorsichtig. Mal sehen was noch alles läuft, wenn Delphi mal komplett auf Unicode umgestiegen ist. |
Re: Speicherbereinigung von Strings
Ergo: eine Wrapperklasse/Record basteln und den String kopieren (was einem 'Add Reference') gleichkommt. Alternativ den String direkt in die Hashmap schreiben
|
Re: Speicherbereinigung von Strings
Zitat:
|
Re: Speicherbereinigung von Strings
Ist für mich verständlicher. Außerdem ist Integer(MyString) <> Integer(@MyString)
|
Re: Speicherbereinigung von Strings
War mir durchaus klar. Aber was ist richtig? Die Adresse eines Pointers? Ist das hier sinnvoll?
|
Re: Speicherbereinigung von Strings
Aus der Systems.pas
Delphi-Quellcode:
Also... Deine Version.. hö hö. Werd ich gleich mal berichtigen.
Type
PStrRec = ^StrRec; StrRec = packed record refCnt: Longint; length: Longint; end; const skew = sizeof(StrRec); rOff = sizeof(StrRec); { refCnt offset } overHead = sizeof(StrRec) + 1; procedure _LStrClr(var S); var P: PStrRec; begin if Pointer(S) <> nil then begin P := Pointer(Integer(S) - Sizeof(StrRec)); ... |
Re: Speicherbereinigung von Strings
@alzaimar: Einen record zu nehmen, bringt eigentlich nichts, denn dann hast du das gleiche Problem mit dem record, weil der schließlich auch freigegeben wird, wenn du nicht seinen Referenzzähler erhöhst.
|
Re: Speicherbereinigung von Strings
Meine Hashmap speichert immer Pointer, daher ein Record bzw. ein Zeiger darauf. Aber ich glaub ich erweitere meine Unit um eine Klasse, die String/String und Cardinal/String Tupel speichert.
|
Re: Speicherbereinigung von Strings
Und wie verhinderst du, dass der record freigegeben wird? Das ist ja dann im Prinzip das gleiche Problem wie bei dem String.
|
Alle Zeitangaben in WEZ +1. Es ist jetzt 22:43 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-2025 by Thomas Breitkreuz