Delphi-PRAXiS
Seite 4 von 4   « Erste     234   

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Sonstige Fragen zu Delphi (https://www.delphipraxis.net/19-sonstige-fragen-zu-delphi/)
-   -   Snake - Ein Problem mit dynamischen Arrays (https://www.delphipraxis.net/167525-snake-ein-problem-mit-dynamischen-arrays.html)

BUG 4. Apr 2012 23:01

AW: Snake - Ein Problem mit dynamischen Arrays
 
Das Exceptions zur Ablaufsteuerung genutzt werden, ist in diesem Fall sicher nicht korrekt.

Aber: Viel schlimmer ist, dass sich darauf verlassen wird, das es einen Speicherzugriffsfehler gibt, wenn man außerhalb des Arrays liest. Es ist nicht garantiert, dass der Speicherplatz um das Array herum nicht lesbar ist. Du könntest also durchaus lesbaren Speicher treffen. Noch schlimmer wird es dann, wenn du dann auch noch reinschreibst :pale:

Mit einer Indexprüfung sollte dieses Problem zwar nicht auftreten, aber weder ist die standardmäßig nicht eingeschalten, noch sollte man sich darauf verlassen, dass das immer so ist.


Zitat:

Zitat von quaxdachs (Beitrag 1160277)
und aus der Theorie geplaudert: ...

Eine Queue (zu Deutsch auch: Schlange :stupid:) für die Schlange zu nutzten ist clever, insbesondere wenn man auf alle Elemente in der Queue zugreifen kann (also nicht wirklich FIFO).
Verabschiede dich von dem Gedanken, dass dein Hinweis theoretisch war. Programmierer (also evtl. auch nicht-Informatiker) sollte eine Queue kennen und ohne viel nachzudenken programmieren können.

Popov 4. Apr 2012 23:30

AW: Snake - Ein Problem mit dynamischen Arrays
 
Liste der Anhänge anzeigen (Anzahl: 1)
Ich habe mal eben Just4Fun ein Snake-Spiel mit TMemo programmiert.

Ist nicht viel drin, nur ein Level. Gesteuert wird mit den Cursortasten.

Coffeecoder 5. Apr 2012 06:49

AW: Snake - Ein Problem mit dynamischen Arrays
 
Zitat:

Zitat von quaxdachs (Beitrag 1160277)
Tach,

aaaalso mein erster Post in einem Delphi-Forum ;-)

Willkommen in der DP :dp:

Zitat:

Zitat von quaxdachs (Beitrag 1160277)
[...]

Ein dynamisches Array ist schon eine nette Idee für die Schlange, allerdings gibt es schönere Datenstrukturen dafür. Z.B. eine FIFO (first in first out). Klassisch wäre dies wohl TQueue, ein Erbe von Collection.
Was den Speicherplatz angeht: bei solchem "Kleinkram" achtet heute niemand mehr auf Speicher, trotzdem ist es schlechter Stil, Speicher zu verschwenden. Willst du also deine Schlange zwingend in einer eigenen Datenstruktur speichern, wäre es ratsam eine eigene Klasse Schlange anzulegen. Die Klasse bekommt intern einen Fifo, mit dem die aktuell belegten Felder gespeichert werden, und enthält Methoden um den Richtungswechsel zu verarbeiten, Position zurück zu geben ect. Hmm... Jetzt bin ich abgeschweift. Zurück zum FIFO: der Fifo muss nur X Elemente speichern, wobei X die Länge der Schlange ist. Du musst dir keine 4 Elemente Pro Schlangen-Abschnitt merken! Theoretisch reicht ein Punkt (x,y) oder noch schöner nur ein Wert Z. Dazu nummerierst du gedanklich deine Positionen durch. Hast du ein Feld, dass a breit ist und b hoch, so sagt dir z.b. x mod a die Zeile in der ein Element ist und x div b die Reihe. Somit musst du maximal pro Sclangen-Teil noch einen Integer speichern (schöner noch nen byte).

Ein sehr interessanter Ansatz 8-) Find ich gut :thumb:

Zitat:

Zitat von Popov (Beitrag 1160290)
Ich habe mal eben Just4Fun ein Snake-Spiel mit TMemo programmiert. Ist nicht viel drin, nur ein Level. Gesteuert wird mit den Cursortasten.

Nett ;) Erinnert mich an meinen Java Konsolensnake 8-)

MrMooed 5. Apr 2012 11:29

AW: Snake - Ein Problem mit dynamischen Arrays
 
Zitat:

Zitat von Popov (Beitrag 1160290)
Ich habe mal eben Just4Fun ein Snake-Spiel mit TMemo programmiert.

Ist nicht viel drin, nur ein Level. Gesteuert wird mit den Cursortasten.

Nett. Allerdings ist, wie bei einer früheren Version bei mir auch, ein Bug enthalten:
man bewege sich nach rechts und drücke schnell hintereinander [RUNTER] + [LINKS]. Dann kommt die Fehlermeldung, dass man sich in den Schwanz gebissen hat. Du hast zwar abgefangen, dass man nicht direkt einen Richtungswechsel in die entgegengesetzte Richtung unternehmen kann, allerdings kann man es mit 2 Bewegungen während des Timers Schaffen dis zu umgehen.
Ich habe es bei mir so gelöst:
Wenn eine Taste gedrückt wird -> Tastendruck := True
Wenn nun Tastendruck 'True' ist, können keine Weiteren Eingaben gemacht werden, bis im OnTimer Event Tastendruck wieder auf False gesetzt wird.

Hat jemand einen besseren Vorschlag ?


P.S.: Klar, dass das nur ein quick-and-dirty Programm ist, wie du schon sagtest.

MrMooed 11. Apr 2012 14:59

AW: Snake - Ein Problem mit dynamischen Arrays
 
Sooo.

Das Programm ist nun soweit fertig und muss felißig getestet werden :lol:
Zu finden ist es hier in der Projekt Abteilung:

nicht noch ein snake klon


Alle Zeitangaben in WEZ +1. Es ist jetzt 06:13 Uhr.
Seite 4 von 4   « Erste     234   

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