Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Object-Pascal / Delphi-Language (https://www.delphipraxis.net/32-object-pascal-delphi-language/)
-   -   Delphi Speicherverwaltung in Delphi (https://www.delphipraxis.net/187212-speicherverwaltung-delphi.html)

Scurra 8. Nov 2015 10:40

Delphi-Version: XE

Speicherverwaltung in Delphi
 
Hallo zusammen,

wie ich u. a. aus der Signatur von einem Forenmitglied gelernt habe, gibt es in Delphi keinen Garbage Collector. Ich habe gelesen, dass Garbage Collectors zum Teil auch den benutzten Arbeitsspeicher defragmentieren können. Jetzt würde mich interessieren, wie das in Delphi läuft. Wird der Arbeitsspeicher dort auch gelegentlich defragmentiert? Kann man auch selbst irgendwie in einem Programm dafür sorgen, dass das passiert?

Was passiert, wenn man mit GetMem (eine größere Menge) Speicher anfordert, der aber nicht an einem zusammenhängenden Stück existiert? Kann Delphi einen Speicher-"Block" (Block ist hier wohl der falsche Begriff) auch fragmentiert reservieren? Damit meine ich folgendes: Wenn ich vereinfacht sagen würde, der Speicher meines PCs besteht aus zehn Einheiten (1 bis 10), ich möchte zwei Einheiten davon reservieren, aber die ungeraden Einheiten sind alle schon belegt, kann Delphi dann diesen Speicher auch reservieren, indem es die Blöcke 2 und 4 reserviert oder gibt es dann eine "Out of memory"-Exception?

Hintergrund der Frage ist, dass ein Programm von der Firma, bei der ich arbeite, bei einem Kunden eine "Out of memory"-Exception ausgelöst hat, obwohl (laut Eureka-Log) noch genug Speicher frei war. Die Idee, die wir hatten, ist, dass der Speicher zu stark fragmentiert war.

Falls jemand Links oder andere Informationsquellen hat, wo ich mich über das Speichermanagement von Delphi informieren kann, bin ich auch schon dankbar :)

BUG 8. Nov 2015 11:06

AW: Speicherverwaltung in Delphi
 
Kurz und knapp: Delphi kann keinen den Speicher nicht defragmentieren/kompaktifizieren, da es Objekte im Speicher nicht verschieben kann. Dazu müsste es entweder alle Objektreferenzen anpassen oder eine Indirektionsstufe verwenden. Zeiger machen das Ganze noch schwieriger/unmöglich.

Bevor du irgendetwas anderes tust, solltest du gucken ob du nicht doch irgendwo ein Speicherleck hast.

dummzeuch 8. Nov 2015 11:28

AW: Speicherverwaltung in Delphi
 
Hi,

Zitat:

Zitat von Scurra (Beitrag 1320867)
Wird der Arbeitsspeicher dort auch gelegentlich defragmentiert? Kann man auch selbst irgendwie in einem Programm dafür sorgen, dass das passiert?

Weder noch.

Zitat:

Zitat von Scurra (Beitrag 1320867)
Was passiert, wenn man mit GetMem (eine größere Menge) Speicher anfordert, der aber nicht an einem zusammenhängenden Stück existiert?

Out of memory.

Zitat:

Zitat von Scurra (Beitrag 1320867)
Hintergrund der Frage ist, dass ein Programm von der Firma, bei der ich arbeite, bei einem Kunden eine "Out of memory"-Exception ausgelöst hat, obwohl (laut Eureka-Log) noch genug Speicher frei war. Die Idee, die wir hatten, ist, dass der Speicher zu stark fragmentiert war.

Das kann der Grund sein. Je nach verwendetem Speichermanager verwaltet der allerdings mehrere Listen von freiem Speicher verschiedener Blockgroessen, um solche Situationen moeglichst zu vermeiden. Ganz verhindern kann er sie aber nicht.

Bernhard Geyer 8. Nov 2015 12:34

AW: Speicherverwaltung in Delphi
 
Wenn die Fremdsoftware ein Delphi-Version mit FastMM als Memory-Manager verwendet ist im Normalfall keine Problem mit Fragmentierung zu erwarten.
Hat es noch den alten Delphi MM in Verwendung dann kann hier leicht ein Problem auftreten.

Wenn das Problem nur bei einem Rechner auftritt sollte man schauen welche "Überlebenswichtigen" Tools installiert sind die in jedem neu gestarteten Prozess DLLs injezieren.
Diese sind (waren) teilweise so compiliert das sie schön verteilt im eigentlich freien Speicherbereich sich ausgebreitet haben und dann Teilweise (nach Programmstart eine 100 MB Allokation nicht mehr klappt).

Scurra 9. Nov 2015 08:55

AW: Speicherverwaltung in Delphi
 
Danke für eure Hilfe. Speziell der Begriff FastMM war auch ganz nützlich, da ich so auf weitere Seiten in der RADStudio-Dokumentation mit Informationen über die Speicherverwaltung in Delphi gestoßen bin.

himitsu 9. Nov 2015 09:31

AW: Speicherverwaltung in Delphi
 
FastMM ist in deinem Delphi aber bereits integriert, da Embarcadero vor paar Jahren eine angepasste/abgespeckte Version des FastMM übernahm.


Alle Zeitangaben in WEZ +1. Es ist jetzt 00:02 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