AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Softwareentwicklung im Allgemeinen Projektplanung und -Management Gibt es ein Design-Pattern für den Programm-Status?
Thema durchsuchen
Ansicht
Themen-Optionen

Gibt es ein Design-Pattern für den Programm-Status?

Ein Thema von mh18058 · begonnen am 20. Okt 2021 · letzter Beitrag vom 2. Nov 2021
 
Benutzerbild von Stevie
Stevie

Registriert seit: 12. Aug 2003
Ort: Soest
4.045 Beiträge
 
Delphi 10.1 Berlin Enterprise
 
#12

AW: Gibt es ein Design-Pattern für den Programm-Status?

  Alt 21. Okt 2021, 14:56
Die meisten wissen nicht, worum es eigentlich geht und wiederholen nur, was sie mal irgendwo gehört haben.

Das Problem bei global state (egal, ob einzelne globale Variablen oder ein fest verdrahtetes Singleton) ist, dass man eher schwerlich entkoppelt testen kann. Wenn Komponente/Klasse/Funktion X hartverdrahtet Y.Irgendwas referenziert, dann muss ich in einem Test immer dafür sorgen, dass Y.Irgendwas auch den richtigen wert für den Testvorgang enthält. Misko Hevery erklärt in seinem Guide recht gut, warum sich daraus Probleme ergeben, sowohl technischer Natur als auch vom Verständnis her, wenn man sich die API von X anschaut, welche möglicherweise nix über ihre "geheime" Interaktion mit Y sagt.

Zudem macht er einen Unterschied zwischen "Singleton" und der "singletoness" - beim Singleton, wie oft implementiert (je nach Sprache mehr oder minder einfach zu realisieren) geht es darum, komplett zu verhindern, dass jemand jemals eine andere Instanz als die einzig wahre erstellen kann (technische Limitierung). Bei der "singletoness" geht es darum, dass es von der Semantik der Anwendung nur eine Instanz gibt. Es steht aber nicht im Weg, zum Testen selbst eine Instanz davon zu erzeugen, um sie für den Test mit entsprechenden Daten zu versorgen, etc oder gar auszumocken.

Am Beispiel von TMessageManager erklärt: Wenn ich in meinem Code überall einfach TMessageManager.DefaultManager.SubscriptToMessage oder SendMessage aufrufe, dann habe ich mich an den Singleton gebunden. Nehme ich über den ctor oder eine Eigenschaft eine TMessageManager Instanz entgehen, mit der ich interagiere, dann habe ich diese Abhängigkeit entfernt bzw "aufgeweicht", denn ich kann von außen steuern, mit welcher TMessageManager Instanz die Komponente kommuniziert.
Stefan
“Simplicity, carried to the extreme, becomes elegance.” Jon Franklin

Delphi Sorcery - DSharp - Spring4D - TestInsight

Geändert von Stevie (21. Okt 2021 um 15:03 Uhr)
  Mit Zitat antworten Zitat
 

 

Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 16:29 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