Best Practice Frage zum MVC-Pattern

C

christian30251

Mitglied
Hallo zusammen!

Im Rahmen meiner Ausbildung zum Software Engineer habe ich jetzt erstmals richtig mit dem Model-View-Controller Pattern zu tun. Ich finde das vom Konzept her - dieses habe ich glaube ich ganz gut verstanden - sehr angenehm. Habe mich eine Zeit lang damit beschäftigt. Wir haben die Aufgabe bekommen, eine kleine Java Anwendung zu entwickeln, mit der Santa Clause seine Geschenklieferungen verwaltet.

Ich möchte gar nicht lange ausschweifen. Das ganze ist vorerst eine Konsolenanwendung, in der man sich am Anfang einloggt (entweder als Kind => Wunschzettel schreiben) oder als Santa (sieht alle Wünsche und Kinder).

Meine Frage ist eher allgemein:
Der Controller ist der Vermittler, das Model modelliert die Objekte und die View stellt alles dar. Soweit klar. Mich würde nur interessieren - gibt es eine "best practice", wie man so etwas umsetzt, dass die einzelnen Module miteinander verknüpft sind, also Model-View-Controller? Also z. B. das Controller-Objekt in der View instanziieren, oder alles im Controller? Gibt es sonst noch Tipps, wie man mit diesem Pattern effizient arbeitet?
Hier fehlt mir leider noch das Know-How, und da wir momentan Weihnachtspause haben, tun wir uns schwer mit Fragen an die Trainer. Vielleicht kann mir ja hier jemand ein paar Tipps geben 🙂

Achja, das ganze hab ich auf Github (wir machen in der Ausbildung vieles via Github Classroom).
Link dazu:


Sollte es nicht funktionieren bitte um Info, dann mach ich ein Duplikat davon als eigenes Repo.

Danke euch schonmal 🙂🙂
 
kneitzel

kneitzel

Top Contributor
Es ist nicht festgelegt, was wo welche Instanz anlegt. Üblich ist z.B. bei Web Applikationen:
- Durch den Request wird im Server ein Controller angelegt.
- Der Controller greift auf die Klassen der pp zu um z.B. Daten zu laden, Aktionen durchzuführen u.s.w. Dabei wird ein Model erzeugt, welches dann an eine View übergeben wird.
- Der Controller muss dann eigentlich nichts von der View wissen, außer evtl. den Namen. Das Framework kann dann z.B. generieren, was der Client zurück bekommt (z.B. Spring MVC mit Thymeleaf -> Der Controller steckt Daten in ein universelles Model und gibt dann nur den Namen der View zurück. Dann kommt das Framework und baut aus Model + View eine Webseite, die zurück geschickt wird.
- Die View erwartet gewisse Daten im Model und greift auf universelle Schnittstellen der Controller zu. Dabei sind die konkreten Controller uninteressant - es interessiert nur der "Vertrag" (Wie sieht die URL aus und was für Daten können mitgeschickt werden...)

Das passt sehr gut, aber sobald man eine statische Applikation hat, wird es schwer. Denn dann gibt es plötzlich durch mehr Möglichkeiten deutlich mehr Anforderungen. Bidirektionale Bindings und so - Dinge die bei einer Web Applikation nicht gehen.

Das bläht dann das Model schnell auf. Statt einfach nur die Daten zu transportieren will man nun Observer-Pattern implementiert haben. Also reicht dann z.B. ein String nicht mehr aus - es muss dann eine StringProperty werden ... Des Weiteren reicht dann schnell der Umfang der Beschreibungssprache nicht aus (also z.B. fxml bei JavaFX) ...

Das Alles führt dann letzten Endes zu einem anderen Pattern MVVM: Model - View - ViewModel. Das ist dann in der Java Welt z.B. mit mvvmFX vertreten. In .Net wäre es bei WPF und co zu finden ...

Aber zurück zu MVC:
In JavaFX wäre es in der Regel so, dass eine View geladen wird (über fxml Datei) und dabei wird automatisch der Controller mit erzeugt. Dadurch hat man eine deutlich stärkere Bindung zwischen View und Controller als üblich.
 
C

christian30251

Mitglied
Super danke für deine Antwort! Hat mir bei der Aufgabe sehr geholfen!! 🙂
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
J Interface Frage zu Interfces am Beispiel Observer Pattern Java Basics - Anfänger-Themen 8
T Frage zu Pattern/Matcher Java Basics - Anfänger-Themen 6
V Frage zu Decorator-Pattern Java Basics - Anfänger-Themen 4
dieter000 Kurze Frage kann mir ejmand kurz diesen Code erklären, bzw wie man die zeilen erklärt und so Java Basics - Anfänger-Themen 1
I String.split regex Frage Java Basics - Anfänger-Themen 2
dieter000 Frage zu einem Beispiel... Java Basics - Anfänger-Themen 5
J Frage zum Loggen Java Basics - Anfänger-Themen 18
J Methoden Frage: Array-Werte in anderer Methode ändern Java Basics - Anfänger-Themen 4
Zrebna Frage zum "Referenzen-konzept" in Java Java Basics - Anfänger-Themen 8
JD_1998 Array-Position aus einer Methode in einer anderen ausgeben (Kurze Frage) Java Basics - Anfänger-Themen 2
marcooooo Frage zu bestimmten Beispiel Java Basics - Anfänger-Themen 31
NeoLexx equals()-Methode Verständnis Frage anhand Code Beispiel Java Basics - Anfänger-Themen 22
N Input/Output Eine Frage über system.out.println. Java Basics - Anfänger-Themen 10
B Erste Schritte Learning Coding (!) Frage an erfahrene Programmierer. Java Basics - Anfänger-Themen 23
M konzeptuelle Frage: In welcher Klasse definiert man am Besten Methoden, die die Kommunikation mit dem User regeln? Java Basics - Anfänger-Themen 8
B Frage zum Code verständnis im Resultat Java Basics - Anfänger-Themen 10
C Exception-Frage Java Basics - Anfänger-Themen 3
J Eine Frage zur Schreibweise == ? : Java Basics - Anfänger-Themen 3
S Frage des Designs Java Basics - Anfänger-Themen 1
JavaTalksToMe Extends/Implements Frage Java Basics - Anfänger-Themen 3
pkm Frage zu Servletfunktion Java Basics - Anfänger-Themen 0
B Frage zur Währungsumrechnung Java Basics - Anfänger-Themen 3
S Allgemeine Frage über Generics und Vererbungen Java Basics - Anfänger-Themen 5
Kirby.exe Frage zur Verwendung von Interfaces Java Basics - Anfänger-Themen 6
D Frage zu Strings einer Exception Java Basics - Anfänger-Themen 4
L Wie frage ich ab, ob in einem Array, Werte doppelt vorkommen? Java Basics - Anfänger-Themen 4
D Frage zur IDE IntelliJ IDEA Java Basics - Anfänger-Themen 6
H Frage zum 2d Array Java Basics - Anfänger-Themen 1
N Frage zum Newton-Fraktal Java Basics - Anfänger-Themen 1
H Frage zu interfaces Java Basics - Anfänger-Themen 1
J Frage dazu Variablen klassenübergreifend zu verändern Java Basics - Anfänger-Themen 22
I Frage zu SkipList Java Basics - Anfänger-Themen 4
G Frage zu JScrollPane Java Basics - Anfänger-Themen 12
Kirby.exe Allgemeine Frage Java Basics - Anfänger-Themen 3
W Frage zu anonymen Klassen Java Basics - Anfänger-Themen 4
J Kleine Frage zu OOP Java Basics - Anfänger-Themen 371
S Frage Klasse und Objekte Java Basics - Anfänger-Themen 2
F Frage zu Iteratoren Java Basics - Anfänger-Themen 2
C Erste Schritte Frage zur ArrayList Java Basics - Anfänger-Themen 15
J Frage zur Vererbung Java Basics - Anfänger-Themen 1
H Frage zur ermittlung eines doppelte Paars aus Sotieralgorithmus Java Basics - Anfänger-Themen 4
H Frage zum Array Java Basics - Anfänger-Themen 17
G Schach -Frage 2- Maussteuerung Java Basics - Anfänger-Themen 7
G Schach in Java - Allgemeine Frage zur Architektur Java Basics - Anfänger-Themen 7
B Fachliche Frage bei Rechnungen Java Basics - Anfänger-Themen 16
B Frage zu: String... strings -> Ungleiche Anzahl an Parameter? Java Basics - Anfänger-Themen 4
B Frage zu Datenbank Design - Rechnungen, Angebote... und deren Positionen Java Basics - Anfänger-Themen 4
H Frage zu Parameter einer Methode Java Basics - Anfänger-Themen 2
H Einfache Frage zur Punktnotation objektname.methode(wert) Java Basics - Anfänger-Themen 2
H Frage zu Parameter einer Methode Java Basics - Anfänger-Themen 3
H Frage zur if-Bedingung bzw switch case Java Basics - Anfänger-Themen 6
H Frage um Eingbeaufforderung zu realisieren Java Basics - Anfänger-Themen 4
H Frage zu Methoden/Funktionen Java Basics - Anfänger-Themen 3
X Frage zur einer ArrayList in einer ArrayList Java Basics - Anfänger-Themen 5
S Frage zu Scanner Java Basics - Anfänger-Themen 3
M Rationale Zahl erkennen - Kurze Frage zum Restwert nach Division Java Basics - Anfänger-Themen 3
D Komplizierte Frage zum Writer Java Basics - Anfänger-Themen 4
I Frage zu Generics und Wildcards Java Basics - Anfänger-Themen 2
G Frage an die Experten Java Basics - Anfänger-Themen 39
H Frage zu fehler Java Basics - Anfänger-Themen 24
F Konstruktor richtig implementiert? Frage zu Benutzereingaben... Java Basics - Anfänger-Themen 9
B Frage zu Arrays Java Basics - Anfänger-Themen 3
O Bedingter Operator eine Frage! Java Basics - Anfänger-Themen 10
B Threads Thread sleep() Method einfache Frage Java Basics - Anfänger-Themen 8
W Stream Array List - Frage Java Basics - Anfänger-Themen 5
B Verständnis Frage zu der Aufgabe Java Basics - Anfänger-Themen 30
Koookie Kleines Frage - Antwort Programm (Anfänger) Java Basics - Anfänger-Themen 5
O Ganz einfache Frage - Array Java Basics - Anfänger-Themen 5
F Erste Schritte Frage zu simplem Taschenrechner(switch) Java Basics - Anfänger-Themen 16
D Frage zu Exceptions Java Basics - Anfänger-Themen 8
H Frage um den Code bildlich darzustellen Java Basics - Anfänger-Themen 2
D regex Aufbau Frage Java Basics - Anfänger-Themen 4
J Frage zu Pfaden Java Basics - Anfänger-Themen 1
J Frage zur Darstellung Java Basics - Anfänger-Themen 2
D Wie frage ich ab ob die Linke maus Taste gedrückt wurde? Java Basics - Anfänger-Themen 3
J Float Frage Java Basics - Anfänger-Themen 1
H Frage zu Übungsaufgabe, Array Java Basics - Anfänger-Themen 7
ralfb1105 Frage zu Thread Synchronisation mit wait() und notify() Java Basics - Anfänger-Themen 3
D Doofe Frage... Java Basics - Anfänger-Themen 2
M Frage, wie dieser Code funktioniert, bzw. weshab er bei mir nicht funktioniert Java Basics - Anfänger-Themen 4
L Frage zu LibGDX Java Basics - Anfänger-Themen 2
O boolean Array Frage! Java Basics - Anfänger-Themen 4
A Frage zur Aufgabe Uhrzeit einstellen mit Objekten Java Basics - Anfänger-Themen 18
S Frage zu Rekursion... Java Basics - Anfänger-Themen 15
S Noch eine Frage zur Rekursion... Java Basics - Anfänger-Themen 11
S Frage zu einer Rekursion Java Basics - Anfänger-Themen 15
S Sudoku Checker Frage Java Basics - Anfänger-Themen 1
pkm Frage wegen möglichem grouping-hack Java Basics - Anfänger-Themen 22
S Erste Schritte Berechnung des Paketportos - Problem/Frage Java Basics - Anfänger-Themen 52
K Operatoren Frage zu Vergleichsoperatoren Java Basics - Anfänger-Themen 3
R Input/Output Frage zu System.out.println Java Basics - Anfänger-Themen 5
J Frage zu: public static void main (String[]args) Java Basics - Anfänger-Themen 1
S Kleine Frage zu Threads Java Basics - Anfänger-Themen 3
N Frage zu this, super und return Java Basics - Anfänger-Themen 13
N Frage zu Streams Java Basics - Anfänger-Themen 3
L Frage zu IntStream (Java 8) Java Basics - Anfänger-Themen 6
N Frage zum dynamischen Polymorphismus Java Basics - Anfänger-Themen 1
J Einfache Frage zu "null" Java Basics - Anfänger-Themen 2
T Erste Schritte Frage zur Initialisierung eines Mehrdimensionalen Arrays Java Basics - Anfänger-Themen 3
D Frage Threads Java Basics - Anfänger-Themen 6

Ähnliche Java Themen

Anzeige

Neue Themen


Oben