Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Programmieren allgemein (https://www.delphipraxis.net/40-programmieren-allgemein/)
-   -   Trennung von Daten und Anzeige [Erfahrungsbericht] (https://www.delphipraxis.net/135337-trennung-von-daten-und-anzeige-%5Berfahrungsbericht%5D.html)

Satty67 9. Jun 2009 09:07


Trennung von Daten und Anzeige [Erfahrungsbericht]
 
Das ist jetzt keine Frage, sondern ein kleiner Erfahrungsbericht:

Vor zwei Wochen fing ein altes Programm von mir an, sporadisch falsche Konfigurationswerte zu speichern. Genauer gesagt ging es um drei Integerwerte, die den ItemIndex von drei Comboboxen gespeichert haben (für Sortier-Reihenfolge).

Gültige Werte sind für ComboBox.ItemIndex bekanntlich Werte >= -1. Dabei wird ComboBox.ItemIndex beim Start (Form.Create) mit 0 initialisiert (erster Eintrag). Da ich so "faul" war und beim Beenden die Werte direkt aus den ComboBox-Objekten in die INI-Datei gespeichert hatte, dürfe da immer ein Wert >= 0 gespeichert werden (dachte ich...).

Sporadisch wurden in der Konfigurationsdatei Werte von -1 gespeichert (kein Item ausgewählt), was bei DropDownList-Comboboxen dann etwas unerwartete Ergebnisse hatte. Zu meiner Schande suchte ich den Fehler auch erst mal in der Speicher-Routine und nicht im "Datenspeicher" ComboBox.

Erkenntnis nach zwei Wochen...

Die Comboboxen liegen auf einem extra Form. Wurde diese nie geöffnet (war ja nur Einstellungs-Fenster), konnte ItemIndex trotz Initialisierung bei Programmstart später ein von der Initialisierung abweichenden Wert enthalten.

Felder (insbesondere Eigenschaften) von visuellen Objekten sind nicht geeignet, von außerhalb als Datenspeicher verwendet zu werden.

DeddyH 9. Jun 2009 09:09

Re: Trennung von Daten und Anzeige [Erfahrungsbericht]
 
Zitat:

Zitat von Satty67
Felder (insbesondere Eigenschaften) von visuellen Objekten sind nicht geeignet, von außerhalb als Datenspeicher verwendet zu werden.

Diese Worte würde ich in Stein meißeln lassen :zwinker:

OldGrumpy 9. Jun 2009 10:14

Re: Trennung von Daten und Anzeige [Erfahrungsbericht]
 
Ein wahres Wort, gelassen ausgesprochen :)

alzaimar 9. Jun 2009 12:47

Re: Trennung von Daten und Anzeige [Erfahrungsbericht]
 
Zitat:

Zitat von DeddyH
Diese Worte würde ich in Stein meißeln lassen :zwinker:

Diese Worte würde ich in Stein die Schädeldecke meißeln lassen.
Diese Worte würde ich in Stein per postcerebraler Schläfenlappenlobotomie flashen lassen.

Satty67 9. Jun 2009 13:53

Re: Trennung von Daten und Anzeige [Erfahrungsbericht]
 
Ich glaube die Initialisierung war sogar nur im Object-Inspector, weshalb die wohl erst beim ersten Fenster-Aufruf übernommen wurden.

Egal, ich kenne die Regel schon lange und erwische mich dabei, wie ich Sie missachte (mache ich später, ach die paar Werte... usw.). Das werde ich mir nie wieder durchgehen lassen ;)

Denn solche Fehler sind wirklich fies. Ich hab' wirklich zwei Wochen gesucht. Beim Öffnen des Fensters zeigten die Listen den richtigen Wert, weshalb ich da gleich einen Fehler ausgeschlossen hatte und ein Überschreiben des Speichers an anderer Stelle oder sonst was ganz seltsames vermutete.

himitsu 9. Jun 2009 14:11

Re: Trennung von Daten und Anzeige [Erfahrungsbericht]
 
hab hier noch ein leicht älteres Programm liegen, da sind alle, aber auch wirklich alle Daten (und das sind da nicht wenige) un der Oberfläche/Anzeige abgelegt :stupid:

Satty67 9. Jun 2009 15:09

Re: Trennung von Daten und Anzeige [Erfahrungsbericht]
 
Ja... mal abwarten ;)

Das Programm, das plötzlich die Werte falsch speicherte ist etwa seit 4 Jahren hier im täglichen Einsatz... und plötzlich fängt das an, meine damaligen Nachläßigkeiten bei der Programmierung für Fehler auszunutzen. Unterschied ist nur, das der Rechner mehr ausgelastet ist.

btw: Ich stelle die letzten Wochen genau das Programm ja um auf SQL und ebenso auf himXML. Im Grunde erfüllt der Zwischenspeicher von XMLfile ja die Anforderung, die Daten getrennt im Programm zu halten.


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