![]() |
Re: Zugriffsverletzung
Zitat:
Wenn ich bedenke das die Methode mehrfach aufgerufen wird ist es hier mehr als nur sinnvoll anstelle von FindComponent ein Array zu verwenden denn wie der Name schon sagt: FINDComponent - es wird also jedesmal gesucht. Ebenso könnte man auch überall ein Sleep rein schreiben um das ganze noch ein wenig auszubremsen. |
Re: Unbekannter Fehler
Hallo
for J := 4 to 7 do (TPanel (FindComponent ('p' + IntToStr (J + 3) J=7 ergibt p10 10 als Zeile hast du aber gar nicht, oder ?. Heiko |
Re: Zugriffsverletzung
Wie schon angedeutet ist der jetzige Code der falsche Weg. Du hast hier massive Probleme und man diese deutlich darauf schieben, dass du in deinem Code-Design nicht Datenverarbeitung und Datendarstellung trennst. Deine Oberfläche soll nur die Daten darstellen, aber nicht halten oder als Basis der Verarbeitung dienen. Wäre dies beachtet worden, dann hättest du vllt. noch falsch angezeigte Oberflächenteile, aber immerhin einen richtigen Programmablauf mit dem richtig ermittelten Status (gewonnen, etc).
Also nochmals als eindringlicher Hinweis: Lege dir ein zweidimensionales Array an, wo du die Werte drin hälst und aktualisiere deine Panels entsprechend den Daten aus diesem Array. Auch ist der Name einer Komponente Schall und Rauch und sollte niemals Einfluß auf den Programmablauf haben, ansonsten wäre es ein sicheres Zeichen, dass die Oberfläche nicht getrennt wäre. Somit: Lege dir als privaten Member ein 2-Dimensionales Array (oder eindimensional, also MOD/DIV nutzen) an in deiner Form, in der du die Panelinstanzen entsprechend hinterlegst. Danach kannst du beim aktualisieren der Oberfläche sogar direkt von Array-Element (Daten) zu Array-Element (Darstellung) arbeiten. Irgendwelche Unsicherheiten mit eventuell nicht gefundenen Panels sind damit schon von vornherein ausgeschlossen. Wer FindComponent() und das nicht gerade in einem eigenen, allgemeinen GUI Streaming Clienten o.ä., der hat falsch programmiert. Diese Funktion ist langsam und wenn man sie dann noch falsch einsetzt (Rückgabewert überprüfen), dann kommt es zu solchen Fehlerausprägungen. Im Normalfall hat man seine nötigen Instanzen fest hinterlegt und arbeitet mit ihnen, aber sucht sie nicht ständig. Das wäre wie jeden Pinsel während des Zeichnens direkt auswaschen und verwahren um ihn dann alle paar Sekunden erneut aus dem Schrank zu holen zum Zeichnen und danach gleich wieder saubermachen und in den Schrank weglegen. Und wenn du schon selber sagst, dass die Routine ständig/oft aufgerufen wird, dann wäre spätestens dies das KO-Kriterium für FindComponent(), selbst bei Programmen ohne Daten/Oberflächentrennung. |
Re: Zugriffsverletzung
Liste der Anhänge anzeigen (Anzahl: 1)
Hihi...
ich erlaube mir mal ein einfaches 0815 Beispiel anzuhängen :oops: |
Re: Unbekannter Fehler
Zitat:
und zu dem ich könnte auch sleep einbaun: das issn kleines game, ich bin noch net sooo weit um programmieren und ich hab das game in paar stunden kurz runtergeschrieben und mir net allzuviele gedanken gemacht, also net so streng sein pls :P |
Re: Zugriffsverletzung
Zitat:
|
Alle Zeitangaben in WEZ +1. Es ist jetzt 22:36 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