![]() |
Unerklärlicher Speicherfresser
Hallo,
ich schreibe gerade mittels Tokyo ein Programm, welches Zeiger auf einen Recordtyp anlegt. Beispiel:
Delphi-Quellcode:
Der Code produziert so natürlich ein Speicherleck, er illustriert aber das Problem
type
TAuthorizationLevel = (alNone, alEverybody, al1, al2, al3); TMyRegister = record Data : Word; WorkingCopy : Word; Authorization: TAuthorizationLevel; Data1 : Word; Data2 : Word; end; PMyRegister = ^TMyRegister; var Reg : PMyRegister; i : Integer; begin for i := 0 to 895 do New(Reg); end. sehr gut. Im eigentlich zu schreibenden Programm ausgeführt, führt er dazu, dass der Taskmanager (ja, der ist da etwas ungenau, die Differenz ist aber frappierend!) einen Speicherverbrauch von ca. 4K pro PMyRegister anzeigt, insgesamt also 3620K. Extrahiere ich den betreffenden Code in ein einfaches Demo Programm (die Schleife im zu schreibenden Programm macht aber NICHTS anders!!!) und führe es aus, brauchen die 895 PMyRegister zusammen nur 20K, ein einzelnes PMyRegister also ca. 22 Byte. Beide Programme sind mit $A8 Speicher ausgerichtet. Woran kann es liegen, dass so ein Record Eintrag einmal ca. 22 Byte benötigt und im anderen Programm, trotz gleicher Definition, ca. 4K. Grüße TurboMagic |
AW: Unerklärlicher Speicherfresser
Hallo,
ich würde mal FastMM4 nehmen, um den tatsächlichen Speicherverbrauch und hier das absichtliche memleak zu prüfen. |
AW: Unerklärlicher Speicherfresser
Hallo,
Tokyo benutzt ja standardmäßig schon FastMM4, allerdings halt "Lite". Angenommen ich nehme die volle Version, wie bekomme ich damit den Speicherverbrauch analysiert? Wie ich damit Speicherlecks ermittle weiß ich schon. Soll ich das also so leaken lassen, damit FastMM4 mir die Größen der geleakten Dinge mitteilt? Grüße TurboMagic |
AW: Unerklärlicher Speicherfresser
Zitat:
|
AW: Unerklärlicher Speicherfresser
Danke Peter, schaue wir uns gleich an.
Wir haben inzwischen versucht mittels der vollen FastMM4 rauszufinden wie groß so ein TMyRegister ist. Wir haben das über das MemoryLeakReporting probiert. Das klappt aus unerfindlichen Gründen aber nur im Testprogramm und dort ist ein TMyRegister 12 Bytes groß. Im eigentlichen Programm kann ich versuchen zu leaken was ich will, er bringt einfach keine Meldung über ein MemoryLeak. Ja ReportMemoryLeaksOnShutdown ist definitiv an und es ist egal ob wir das in Tokyo eingebaute limitierte reporting nutzen oder FastMM4 aus dem Internet. Er zeigt das nicht an :-( Grüße TurboMagic |
AW: Unerklärlicher Speicherfresser
Hallo,
Zitat:
Nach dem Beenden deines Programmes erhälst Du eine Datei, die die Klassen (Objekte) anzeigt, die nicht freigegeben worden sind. Ausserdem die Größe des jeweiligen Objektes, wenn also "falsch" ausgerichtet wird, auch die Gesamtgröße (glaube ich ...) Mit deiner "kleinen", eingebauten Version schreibst du als erste Zeile in die DPR ReportMemoryLeaksOnShutdown := True; |
AW: Unerklärlicher Speicherfresser
Hallo,
das heisst, in einem Testprogramm klappt es, in deinem richtigen Programm nicht? Das ist was faul ... Vergleiche mal die Compiler-Optionen der beiden Programme. Suche im kompletten Quellcode nach ReportMemoryLeaksOnShutdown, nicht das das irgendwo ausgeknippst wird. FastMM4 ist wirklich in der DPR? Nimm dein grosse Projekt, mache ein Exit noch vor dem Erzeugen des Hauptforms und davor das Speicherleck rein, also ein Objekt oder per GetMem das erzeugen und nicht freigeben. Damit kannst du prüfen, ob es irgendwas mit den Projektoptionen zu tun hat. Hie noch mal der Link für die Settings von FastMM4. ![]() |
AW: Unerklärlicher Speicherfresser
Nur mal ins Blaue hinein: Ist das eine evtl. ein Debug- und das andere ein Release-Build?
|
AW: Unerklärlicher Speicherfresser
Zitat:
|
AW: Unerklärlicher Speicherfresser
Zitat:
|
Alle Zeitangaben in WEZ +1. Es ist jetzt 06:52 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