Input/Output MVC - Frage zum Verständnis

R

Ron90

Gast
Hi,

ich möchte/muss momentan etwas mit dem Entwurfsmuster des Model-View-Controller machen.
So ganz 100%ig blick ich da nicht durch.

-Der Controller kümmert sich um die eingegebenen Daten d.h. eine Eingabe bekommt erst der Controller und wandelt diese dann z.B. in das gewünsche Format um.
Wenn alles OK ist, dann schickt er die Daten an das Model weiter. Wenn z.B. was falsch ist, dann sagt er der View z.B. "lösche das Textfeld und gib deine Fehlermeldung aus" und die Daten gehen erst garnicht an das Model.
>>Controller kennt View und Model

-Das Model schickt die Daten immer direkt an die Views.
>>Model kennt Controller nicht

Möglicher Ablauf:
Eingabe von der Zeichenkette 10,50€ > weiter an Controller >
Controller wandelt z.B. den String in die Zahl 1050 um > weiter an Model >
Model rechnet mit 1050 > Ergebnis weiter an View
> Die View kümmert sich (immer?) um die Darstellung.

Die View fragt nur beim Model nach Informationen z.B. "Wie ist der Kontostand?"
>>View kennt Model
Sobald die View was ändern will, ist der Controller sowas wie ein Beamter der die Daten kontrolliert.
Er geht dann zum Model und sagt: "Da hat Jemand gerade 10.50€ eingezahlt", das Model aktualisiert den Kontostand und schickt die neuen Daten an alle Views.
An der Stelle ist mir wirklich unklar, warum der Datenaustausch von Model nach View geht und nicht von Model über Controller nach View?
Das Model muss doch nicht alle Views kennen? Er brauch Änderungen doch nur an den Controller zu schicken und der Controller schickt die Änderungen dann an alle Views (die er eh schon alle kennt).
Oder ist es darauf zurückzuführen, dass die Daten die ein Controller bekommt nicht immer von einer Quelle mit einer eigenen View kommen müssen (Eingabegerät: z.B. Fernbedienung für Heizung.).

mfg
 

Evil-Devil

Top Contributor
Generell gesehen hast du das schon richtig verstanden. Allerdings kann man MVC nicht immer 1:1 nach dem Lehrbuch umsetzen. Zb. kommt es vor das View und Model in der selben Klasse abgebildet werden und man somit (MV)C hat.

Der Controller selbst sollte so wenig wie möglich von Models und Views kennen/wissen. Im Idealfall kennt er nur sein Modell und lässt über selbiges veranlassen das die Daten angezeigt werden.

Je nach Anwendung können in der Tat die Eingaben aus verschiedenen Quellen stammen. Zb. Benutzeroberfläche (Website), Automatismus (Server) und Datenbanken Dritter. Der Phantasie sind hierbei keinerlei Grenzen gesetzt.
 
I

Icke2222

Gast
Das Model muss doch nicht alle Views kennen? Er brauch Änderungen doch nur an den Controller zu schicken und der Controller schickt die Änderungen dann an alle Views (die er eh schon alle kennt).

Hier denke ich verstehst Du etwas falsch. Das Datenmodell kennt nichts außer sich selbst. Das View wiederum kennt das Datenmodell, da es genau dieses darstellen kann. Zum Beispiel könntest Du Dir vorstellen, dass eine Anwendung aus Personaldaten besteht. Das Datenmodell legt fest, wie so ein Datensatz, sagen wir mal eine Person aussieht. Die hat eine Personalnummer (ID), einen Namen und ein Gehalt (ist ebenso sinnfrei wie einfach).

Das View legt jetzt fest, wie man so einen Datensatz anzeigt. Dazu liest es einfach eine Person aus und bekommt ein Objekt (Exemplar einer Klasse), dass eben dem Modell zugeordnet wird.

Es muss hier also weder das Modell alle Elemente des Views kennen (ganz im Gegenteil), noch muss jedes Element im View das gesamte Modell kennen.

Tatsächlich ist es auch möglich (und für eine strikte Trennung sinnvoll) die Kommunikation stets über eine Zwischenschicht laufen zu lassen. Im MVC pattern ist die Festlegung was genau durch welche Schicht erledigt wird, nun ja, wenig strikt. Deshalb gibt es heute gerne Varianten wie MVP (wird zum Beispiel für GWT verwendet), die da etwas klarer rangehen.
 

Spin

Top Contributor
Hallo Ron,

Ich möchte/muss momentan etwas mit dem Entwurfsmuster des Model-View-Controller machen.

aufgehts. ;)

Also ein Model ist ein Domainobjekt, welches die Anwendungsdaten kapselt.
Für die Anfrage an die Datenbank sollte man sich ein Mapper bauen, der die DB Queries ausführt und anschließend das Ergebnis einem Model zu weist.

Als Anfänger musst du nur wissen, das ein Model zum speichern und laden von Daten vorgesehen ist + das halten von Daten. Sobald du dich damit mehr beschäftigst, trenne die Anfragen zur Datenbank vom Model in einen Mapper. Die Connection sollte dann in eine Factory oder in ein Singleton gepackt werden. (Vergiss den Satz - da hier zwei weitere Design Pattern angesprochen werden)

Der Controller ist der Einstieg. Controller für Detkop oder Webanwendungen ? Im beiden fällen stellt er die Steuerung der Daten dar. Der Controller kennt seine Models und seine Views und kann die Daten entsprechend weiter geben. Das ist die einfachste und legitimste Variante.

Eine andere ist das der Controller kein Model kennt und nur die Views.
Benutzeraktionen im View werden dem Controller weitergereicht, dieser wertet die Anfrage aus und aktualisiert den Zustand des Models. Das Model benachrichtigt darauf hin das View, was sich anschließend die Daten vom Model abholt und sich selbst erneuert. (Das passiert über ein Observer Pattern .. auch zu viel für den Einstieg).

Such bische im Netz, nach how to mvc in java und du findest Bieispiele ohne Ende. Du kannst dann schauen welche Kompositionen wo verwendet werden.

grüße spin
 
C

Camino

Gast
Eine andere ist das der Controller kein Model kennt und nur die Views.
Benutzeraktionen im View werden dem Controller weitergereicht, dieser wertet die Anfrage aus und aktualisiert den Zustand des Models.

Ist das nicht ein Widerspruch?! Wie soll der Controller das Model aktualisieren, wenn er es nicht kennt?
 

Spin

Top Contributor
Hey Camino,

über einen ServiceLocator, vie Dependency Injection :p So bauen wir immer MVC Anwendungen. Unser Controller kennt keine Models, sondern nur einen EntityManager oder einen ServiceManager, die via Dependency die Abhängigen Objekte übergeben.

Aber - ich habe mich tätsächlich vertan. Der Controller darf auch bei der zweiten Variante das Model kennen, sorry.

Ich finde es aber perönlich besser, einen Controller nur die HTTP Requests oder Ereignisse entgegen nehmen zu lassen und dann zu prüfen. Die Weiterleitung dieser Ergbnisse wird dann von den Oben genannten Manager durchgegeben. Ob das nun zum ("Model" gehört oder nicht alls ich euch entscheiden - die Diskussion hatte ich schon vor .... !

Wollte das nur klar stellen@ TO das Camino auf jeden Fall richtig liegt, dass ich dort einen Widerspruch eingabut habe :eek:
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
N Verständnis Frage zu Variablen Java Basics - Anfänger-Themen 3
S Verständnis-Frage zu einer HÜ? Java Basics - Anfänger-Themen 1
NeoLexx equals()-Methode Verständnis Frage anhand Code Beispiel Java Basics - Anfänger-Themen 22
B Frage zum Code verständnis im Resultat Java Basics - Anfänger-Themen 10
B Verständnis Frage zu der Aufgabe Java Basics - Anfänger-Themen 30
I Verständnis Frage wegen einer Aufgabe Java Basics - Anfänger-Themen 10
P verständnis Frage Refernzen und Objekte Java Basics - Anfänger-Themen 1
S Verständnis - Frage mehrere SQL Statements in While Schleife Java Basics - Anfänger-Themen 0
J Musterlösung Verständnis Frage zu Math.abs() Java Basics - Anfänger-Themen 5
X Kompilat verständnis Frage Java Basics - Anfänger-Themen 9
C Input/Output Anfänger Array-Verständnis Frage Java Basics - Anfänger-Themen 7
F Verständnis Frage - && Java Basics - Anfänger-Themen 2
O Frage zu Verständnis von Collection Java Basics - Anfänger-Themen 4
C Methoden Frage zu Verständnis eines Beispiels Java Basics - Anfänger-Themen 3
M Verständnis Frage Java Basics - Anfänger-Themen 11
T Verständnis-Frage Java Basics - Anfänger-Themen 2
E Verständnis frage zum return wert eines Arrays Java Basics - Anfänger-Themen 7
S Frage zu Verständnis und Logik Java Basics - Anfänger-Themen 5
A Array Verständnis Frage Java Basics - Anfänger-Themen 4
L Hashtable Verständnis Frage Java Basics - Anfänger-Themen 4
J Frage zum Quellcode - Zusammhänge und Ablauf. Java Basics - Anfänger-Themen 2
D Erste Schritte Frage eines absoluten Anfängers Java Basics - Anfänger-Themen 3
Zrebna Frage zu Test-Driven Development (TDD) Java Basics - Anfänger-Themen 3
I Frage Thymeleaf -> Fehler ignorieren und mit "" ersetzen? Java Basics - Anfänger-Themen 15
I Frage Thymeleaf -> Prefix / Suffix ändern? Java Basics - Anfänger-Themen 11
D Rekursions Probleme / frage Java Basics - Anfänger-Themen 4
T Frage zu Parse Java Basics - Anfänger-Themen 2
H Frage an die Profis Java Basics - Anfänger-Themen 4
J Eine konzeptionelle Frage zu OOP Java Basics - Anfänger-Themen 3
P Frage zu Rekursion und Backtracking Java Basics - Anfänger-Themen 2
H Frage zur Ausgabe Java Basics - Anfänger-Themen 4
H Frage zu arithmetischen Operationen Java Basics - Anfänger-Themen 20
F Kurze Frage zu replace() Java Basics - Anfänger-Themen 19
JavaSchmecktLecker Polymorphie Frage zur Methodenüberschreibung Java Basics - Anfänger-Themen 21
J Frage zu einem "Taschenrechner" code Java Basics - Anfänger-Themen 9
B Erste Schritte Frage zu Instanzierung und Referenzen Java Basics - Anfänger-Themen 8
DoubleM Runtime.getRuntime().exec Frage Java Basics - Anfänger-Themen 2
J Eine theoretische Frage zur Praxis - JPanel oder Canvas Java Basics - Anfänger-Themen 5
O Frage: Formaler Typbezeichner? Java Basics - Anfänger-Themen 3
I BlueJ Queue Frage für Klausur Java Basics - Anfänger-Themen 2
N Spezielle frage zum Comparator Java Basics - Anfänger-Themen 6
L Frage zum Array Java Basics - Anfänger-Themen 1
A Frage zum UML Design Java Basics - Anfänger-Themen 1
I Hilfe bei Klausur Frage Java Basics - Anfänger-Themen 8
izoards Drucken Frage zu FAQ Beitrag Java Basics - Anfänger-Themen 2
J Frage zu meinem Code (OOP) Java Basics - Anfänger-Themen 4
sserio Split() -> Regex Frage. Java Basics - Anfänger-Themen 7
A OCA Study Guide: 2. Frage aus Kapitel 3 Java Basics - Anfänger-Themen 9
sserio Date Library Frage Java Basics - Anfänger-Themen 9
Max246Sch Frage zu Währungsrechner Code Java Basics - Anfänger-Themen 2
sserio Frage zu HashMaps Java Basics - Anfänger-Themen 20
sserio Frage zu Threading - Multithreading Java Basics - Anfänger-Themen 2
sserio Frage zu Lambda Ausdrücken Java Basics - Anfänger-Themen 7
sserio Frage zu BigInteger Java Basics - Anfänger-Themen 1
D Frage bzgl. Enum-Handhabung Java Basics - Anfänger-Themen 16
xxx12 Frage Java Basics - Anfänger-Themen 2
I Generelle Frage zu Mikroservices (Spring Boot?), Docker... Java Basics - Anfänger-Themen 7
R Frage zu Methoden (Rückgabewert u. ohne.) Java Basics - Anfänger-Themen 2
A Frage zur programmierung Java Basics - Anfänger-Themen 12
M Frage zur Methode split der Klasse String Java Basics - Anfänger-Themen 32
R Input/Output Frage zu Java IO Java Basics - Anfänger-Themen 6
M Frage zu printWriter Java Basics - Anfänger-Themen 5
C Frage zu OLSMultipleLinearRegression Java Basics - Anfänger-Themen 31
KogoroMori21 Frage zum Euklidischen Algorithmus Java Basics - Anfänger-Themen 11
F Frage betreff Programm mit dem man C++-Code in JAVA-Code übersetzen lassen kann Java Basics - Anfänger-Themen 2
L Frage zur Ticket Maschine Java Basics - Anfänger-Themen 1
J Frage zu OOP-Klassendiagramm Java Basics - Anfänger-Themen 8
OSchriever Frage zu Compiler Java Basics - Anfänger-Themen 8
H Frage zu Throw Exception Java Basics - Anfänger-Themen 2
TimoN11 Frage zu Java-Vererbung (Cast) Java Basics - Anfänger-Themen 5
Bademeister007 Hallo Leute ich hab eine Frage zur ArrayList Java Basics - Anfänger-Themen 8
F Frage betreff Programmierbücher zu Lagerverwaltung als Konsolenprogramm Java Basics - Anfänger-Themen 3
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
N Best Practice Frage zum MVC-Pattern 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
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
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

Ähnliche Java Themen

Neue Themen


Oben