AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Programmieren allgemein Delphi ClassFactory ähnlich wie Spring Framework, Hilfe gesucht!

ClassFactory ähnlich wie Spring Framework, Hilfe gesucht!

Ein Thema von Mavarik · begonnen am 6. Feb 2014 · letzter Beitrag vom 9. Feb 2014
Antwort Antwort
Benutzerbild von Stevie
Stevie

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

AW: ClassFactory ähnlich wie Spring Framework, Hilfe gesucht!

  Alt 7. Feb 2014, 11:54
Es hat sich mir auch nicht erschlossen, warum ich die Implementierung des Interfaces nicht in der gleichen Unit machen soll.
Das erschließt sich meist erst, wenn man eine größere bzw "richtige" Anwendung hat. In dem Fall ein Interface, eine Klasse mag es erstmal unnötige Arbeit sein, das in eigene Unit zu packen, aber wenn diese dann von anderen Teilen benutzt merkt man, dass man bei einer Trennung dort tatsächlich nur eine Abhängigkeit auf die Abstraktion (Interface) hat und sich auch nicht von hinten rum, die Implementierung rein holt (weil sie in derselben Unit wie das Interface ist). Wenn man mehrere Implementierungen für ein Interface hat, fällt es direkt auf. Und wenn man dann einen Unittest für Klasse A schreibt, die Interface B benutzt, was man nur ausmocken muss, aber trotzdem Klasse B im Test drin ist, auch.

Man merkt sowas immer schnell, wenn man mal kurz eine kleine Testapplikation schreibt, welche ein TToaster testen will. Und plötzlich wundert man sich, dass in die Anwendung auch TStadtwerke , TUmspannwerk , TKraftwerk und TBraunkohletagebau einkompiliert werden, nur weil man den TToaster an den Strom anschließen kann.

Ich stimme dir aber zu, wenn man das so praktiziert, kann das zu langen uses Klauseln kommen, dahingehend hat man es in Java oder C# einfacher mit richtigem Namespacing (so nach dem Motto uses MyLib.*; statt uses MyLib.Foo, MyLib.Bar, MyLib.MoreStuff, ...; ).
Stefan
“Simplicity, carried to the extreme, becomes elegance.” Jon Franklin

Delphi Sorcery - DSharp - Spring4D - TestInsight

Geändert von Stevie ( 7. Feb 2014 um 11:58 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von Uwe Raabe
Uwe Raabe

Registriert seit: 20. Jan 2006
Ort: Lübbecke
11.771 Beiträge
 
Delphi 12 Athens
 
#2

AW: ClassFactory ähnlich wie Spring Framework, Hilfe gesucht!

  Alt 7. Feb 2014, 12:46
Ich stimme dir aber zu, wenn man das so praktiziert, kann das zu langen uses Klauseln kommen, dahingehend hat man es in Java oder C# einfacher mit richtigem Namespacing (so nach dem Motto uses MyLib.*; statt uses MyLib.Foo, MyLib.Bar, MyLib.MoreStuff, ...; ).
Dieses Feature birgt aber wiederum andere Gefahren: Damit würden ja alle Units dieses NameSpace (MyLib) eingebunden die im Suchpfad gefunden werden. Das wäre mit den aktuellen Units von Delphi XE5 schon mal nicht praktikabel, da dort z.B. plattformabhängige Units gleichnamige Methoden deklarieren (bei FMX z.B. FMX.Controls.<Android|iOS|Mac|Win>). Bei einem NameSpace FireDAC.* hätte man plötzlich alle verfügbaren Datenbanktreiber mit eingebunden, was in den seltensten Fällen wirklich erwünscht ist. Für selbstgestrickte Units kann man da sicher Vorkehrungen treffen, aber dann müssen die NameSpaces und Unitnamen auch gut überlegt sein.
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  Mit Zitat antworten Zitat
Benutzerbild von Stevie
Stevie

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

AW: ClassFactory ähnlich wie Spring Framework, Hilfe gesucht!

  Alt 7. Feb 2014, 16:53
Dieses Feature birgt aber wiederum andere Gefahren: Damit würden ja alle Units dieses NameSpace (MyLib) eingebunden die im Suchpfad gefunden werden. Das wäre mit den aktuellen Units von Delphi XE5 schon mal nicht praktikabel, da dort z.B. plattformabhängige Units gleichnamige Methoden deklarieren (bei FMX z.B. FMX.Controls.<Android|iOS|Mac|Win>). Bei einem NameSpace FireDAC.* hätte man plötzlich alle verfügbaren Datenbanktreiber mit eingebunden, was in den seltensten Fällen wirklich erwünscht ist. Für selbstgestrickte Units kann man da sicher Vorkehrungen treffen, aber dann müssen die NameSpaces und Unitnamen auch gut überlegt sein.
Ich wär ja schon glücklich, wenn man generische Typen redeklarieren könnte, dann könnte man sich so pseudo Namespace Units bauen, wo man Dinge aus anderen Units zusammenführen kann.
Stefan
“Simplicity, carried to the extreme, becomes elegance.” Jon Franklin

Delphi Sorcery - DSharp - Spring4D - TestInsight
  Mit Zitat antworten Zitat
Antwort Antwort

Themen-Optionen Thema durchsuchen
Thema durchsuchen:

Erweiterte Suche
Ansicht

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 06:18 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