![]() |
EInvalidPointer
Liste der Anhänge anzeigen (Anzahl: 1)
Hi,habe mal den Code angehängt, zum besseren Verständnis!
Frage: Wie kann es sein, das wenn ich das Programm schließe, mir ein solcher Fehler angezeigt wird, genauso mit der Prozedur, inder man die Größe des Spielfeldes ändern kann. Aber beim Schließen?!? Wo könnten die möglichen Fehler sein und wie kann man sie beseitigen?!? thx for any help! :) |
Moin Madeleine,
ich bin mir jetzt nicht sicher, ob's daran liegt, aber mir ist aufgefallen, dass Du fleissig Bitmaps erzeugst, aber nur das jeweils letzte erzeugte auch wieder freigibst, wenn das Formular geschlossen wird. Jedesmal, wenn Du TBitmap.Create aufrufst, wird ein neues Bitmapobjekt erzeugt. Dadurch werden dann Resourcen belegt, die auch wieder freigeben werden müssen. Die grundlegende Vorgehensweise sieht eigentlich so aus:
Das heisst: Jedes Create benötigt auch ein Free. Wie man das jetzt macht hängt auch davon ab, an welchen Stellen man es im Programm braucht. Die drei Möglichkeiten, die mir da so auf Anhieb einfallen wären:
Auf den ersten Blick scheint mir bei Deinem Programm die 2. Variante am passensten zu sein, da Du die entsprechenden Variablen ja als Felder des Formulares deklariert hast. Es genügt dann einfach die beiden Felder im OnCreate des Formulares zu erzeugen, dort auch ihre Werte einzustellen (z.B., wie Du es machst den Inhalt aus einer Datei zu laden), im Programm zu benutzen, und dann im OnDestroy wieder freizugeben. |
Hi Chris,
danke für die gut verständliche Erklärung, habe es so gemacht wie du es empfohlen hast, aber der Fehler ist immer noch da, mit den Bitmaps wird es wohl nicht zusammenhängen! Ich denke, es liegt daran, das wenn ich jetzt im Fall des Spielfeldes ändern,ok geklickt habe, das dann wieder FormCreate aufgerufen wird und die dynamischen Arrays zweimal deklariert werden. Habe deshalb FormResize geschrieben, aber das hat auch nicht geholfen! Hat noch jmd ne Idee? *hoffnungsvoll in die Runde schau* |
Hallo Madeleine,
wenn du den EInvalidPointer beim Beenden Deines Programmes bekommst gibt es mehrere Möglichkeiten. 1. Du greifst in deiner OnClose-Ereignisbehandlung auf Zeiger zu die nicht mehr existent sind. (Sieht hier erst mal nicht so aus) 2. Viel eklieger, du hast Ereignisbehandlungen geschrieben (z.B. OnRecize) die mit Zeigern arbeiten. Setze bei jeder Methode in der du global definierte Zeiger verwendest einfach eine Prüfung vorweg. So nach der Art: IF not Assigned(Zeiger) then Exit; oder IF Zeiger = nil then Exit; Achte aber darauf, dass die zu prüfenden Zeiger nach der Freigabe auf nil gesetzt sein sollten!! Ich hab die Erfahrung gemacht das freigegebene Zeiger nicht automatisch auf nil gesetzt werden. (Verwendest du Handle prüfe auf 0 (null)) Also, prüfe mal mit einem Brakepoint auf OnClose und mit Step-byStep Methode (F7) welcher Zeiger spinnt. Den dann prüfen (wie oben) und mit Exit raus aus der Methode. Gruß Olaf |
Moin Oki,
Zitat:
|
Hallo Christian,
man lernt nie aus! Danke für den Tip. Gruß Olaf |
Alle Zeitangaben in WEZ +1. Es ist jetzt 08:42 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