Klassenstruktur für einen Java-Chat

Status
Nicht offen für weitere Antworten.

m!k3

Bekanntes Mitglied
Hi,

ich hätte da mal ne Frage... also ich bastel ja an einem Java-Chat der immer mehr Umfang annimmt.

Ist es nun sinnvoll den Client in mehrere Klassen zu unterteilen, oder sollte man sowas nicht tun.

Mir wurde mal gesagt eine Java-Anwendung besteht aus einer Klasse und für weitere Klassen sollte man eine neue Anwendung anlegen. Aber das finde ich auch keine tolle Lösung bei den Geschichten, für die ich es verwenden würde.
Ich unterteile z.B. den Server + mySQL Zugriffe in zwei seperate Java Anwendungen.

Aber nun für den Client habe ich jetzt drei Frames - Anmeldung - Chat - Registrierung

Anmeldung und Chat sind momentan ein Frame, was ja eigentlich auch nicht schön ist. Ich ändere eben die Komponenten und die Größe.

Nun überleg ich eben ob ich nicht mehrere innere Klassen mache. Zum Beispiel sowas:

Mögliche Klassen:

Anmeldeframe
Hauptframe
Registrierungsframe
Chatlogik (sozusagen die Hautklasse)

Also was ist nun schön programmiert und was nicht?! Wo sind die Profis?! ;)
 

P3AC3MAK3R

Top Contributor
Mir wurde mal gesagt eine Java-Anwendung besteht aus einer Klasse und für weitere Klassen sollte man eine neue Anwendung anlegen.
Wer immer das gesagt hat, hat wohl nicht wirklich viel Ahnung von objektorientierter Softwareentwicklung. ;)

Es ist durchaus üblich und unbedingt empfehlenswert eine Anwendung in mehrere Klassen aufzuteilen. Anderfalls ist diese vermutlich irgendwann schwer bis überhaupt nicht mehr pflegbar.
 

m!k3

Bekanntes Mitglied
tschuldigung.. dacht das sei Aussagekräftig.. der Chat war ja nur n Beispiel.. es ging/geht mir ja darum Java schön zu programmieren.. :oops:
 

P3AC3MAK3R

Top Contributor
"Java schön programmieren" klingt ehrlich gesagt nicht unbedingt nach Fachsprache. ;)
Deswegen und weil man sich sonst etwas darunter vorstellen kann, habe ich den Titel eben präzisiert.
 

apfelsine

Aktives Mitglied
Mir wurde mal gesagt eine Java-Anwendung besteht aus einer Klasse und für weitere Klassen sollte man eine neue Anwendung anlegen.

wer hat dir denn so einen ... erzählt.
Vergiss das am besten gleich wieder :)
Im Prinzip solltest du deine Klassen nach zusammengehörigen Teilbereichen aufteilen.
Ich nenne das Makroteile.
Wenn man eine Anwendung bastelt, sollte man sich überlegen welche Teile zusammen
gehören.
Ich würde auf jeden Fall zwischen Datenhaltenden Klassen und Geschäftsregel Klassen
trennen.
Das bedeutet z.B.
Ich hätte meinetwegen eine Klasse ClsUtils wo meine Methoden enthalten sind die
etwas tun wie Laden(), Connect() usw.
und ich hätte meinetwegen eine Klasse ClsBenutzer in der ich die Eigenschaften
des Benutzers ablegen kann
und ich hätte eine Klasse ColBenutzer die wiederum eine Collection von ClsBenutzer darstellt, sodass
ich immer einfach neue Benutzer hinzufügen kann oder entfernen...und was sonst noch sinnvoll
ist.

Über dieses Thema gibts haufenweise Bücher. Unter anderem "Softwarearchitektur" von Holitschke zum Beispiel.

also grundregel: aufteilen in sinnvoll zusammengehörige Klassen

und auch nicht alles in "einer" Datei.
das wird auf Dauer unübersichtlich.

gruß
apfelsine

PS:ansonsten gilt, was eigentlich für jede Programmiersprache gilt:
keep it simple and stupid -heißt tausend verschachtelte Aufrufe ist zwar supertoll, aber
für einen der sich in fremden Code einarbeiten muß beschissen.
und für dich wenn du ihn ein halbes jahr nicht angeschaut hast genauso.
Einheitliche Variablendeklarationen gehören auch zum a und o
man kann die liste noch ewig fortsetzen, aber das lass ich jetz ma :)
 
B

Beni

Gast
m!k3 hat gesagt.:
Ist es nun sinnvoll den Client in mehrere Klassen zu unterteilen, oder sollte man sowas nicht tun.
Es ist in der Tat nie sinnvoll mehr als eine Klasse zu verwenden. Wo kämen wir denn da hin, wenn unsere Dateien plötzlich weniger als 10'000'000 Zeilen Code hätten? Es würde nicht nur übersichtlicher, nein, es würde auch noch objektorientierter!

m!k3 hat gesagt.:
Mir wurde mal gesagt eine Java-Anwendung besteht aus einer Klasse und für weitere Klassen sollte man eine neue Anwendung anlegen.
Das ist vielleicht ein sprachliches Missverständnis. Mit Anwendung wird hier wohl nicht Programm, sondern was wie "Themengebiet" oder "Eigenschaft" gemeint.

Ich könnte mir schon vorstellen das Hauptfenster auf 5 Klassen zu verteilen (MenüBar, Chatfenster-Teil, Teilnehmer-Liste, ...).
 

m!k3

Bekanntes Mitglied
ah ich verstehe.. okay dann hab ich ihn Missverstanden... weil.. der kennt sich schon gut aus.. wenn nich sehr gut :lol:

also ich hatte ihn mal gefragt, ob ich zum Chatserver die mySql Zugriffe als separate Anwendung vollziehen soll, oder als eine zweite Klasse.

Daraufhin meinte er das sowas in Java unsinnig ist, wegen den verschiedenen Themen.
 

Bleiglanz

Gesperrter Benutzer
also ich hatte ihn mal gefragt, ob ich zum Chatserver die mySql Zugriffe als separate Anwendung vollziehen soll, oder als eine zweite Klasse.
was meinst du mit "seperater Anwendung"? Natürlich gehört der Datenbank-Zugriffs-Zeugs in eigene Klasse(n), die ganze restliche Anwendung sollte keinerlei Bezug auf eine Datenbank haben, sonder über Interfaces auf so einen "Service" zugreifen
Daraufhin meinte er das sowas in Java unsinnig ist, wegen den verschiedenen Themen.
kann ER auch deutsch? Hä?
 

m!k3

Bekanntes Mitglied
also zu Bleiglanz sag ich jetzt mal gar nix...

ich bin aber irgendwie auch der Meinung mit mehreren Java Anwendungen was zu lösen anstatt in einer mit mehreren inneren Klassen.

Innere Klassen sind für mich KeyListener etc.

Aber wenn wir jetzt beim Chat bleiben, ist es doch viel sinnvoller in mehrere Java Dateien zu unterteilen

- Logik ( Server - Client Kommunikation )
- Anmeldeframe
- Chatframe
- Registrierungsframe
- Chatserver ( ist sowieso eine eigene Datei )
- ChatSql ( gehört zum Server )

Man hält so das Ganze viel übersichtlicher und noch strukturierter - ist jetzt meine Meinung. Also kann nicht verstehen warum ihr so der Meinung seit 10 000 Zeilen Code in eine Datei zu pressen und das noch übersichtlich und objektorientiert sein soll.. also soll jetzt nicht böse rüberkommen... möcht halt nur drüber diskutieren, deshalb sag ich jetzt auch nichts zu Bleiglanz... 8)
 
R

Roar

Gast
ich bin aber irgendwie auch der Meinung mit mehreren Java Anwendungen was zu lösen anstatt in einer mit mehreren inneren Klassen.

nicht dass du da was falsch verstehst: Klassen != Anwendung. Eine Java Anwendung besteht immer aus mehreren klassen

und das letze mit den 10000 zeilen in einer datei war ironisch gemeint von Beni... naja das macht ja nix, er is ja schweizer die versteht man eh nie *fg* :bae:
 

Heiko

Bekanntes Mitglied
Also ich bin der Meinung, dass nur das was zusammengehört in einer Klasse stehen muss, von daher klingt dein Ansatz doch gar nicht so schlecht.

Also sind 10.000 Zeilen schon ziemlich heftig, und ich denke Beni hat das auch eher ironisch gemeint.
 

m!k3

Bekanntes Mitglied
ja ich wollts ja auch nochmal ironisch darstellen ;)

mir ist klar das eine Anwendung aus mehreren Klassen bestehen kann. Aber ich halte es doch für viel sinnvoller in mehrere Anwendungen zu unterteilen und beispielsweise innere Klassen wie KeyListener etc. zu benützen, anstatt jetzt eine innere Klasse mit "LoginFrame" zu erstellen.

Die Übersichtlichkeit geht doch komplett verloren.. und dadurch ging es auf gut 2000 Zeilen Code, das ich jetzt viel besser kompremieren konnte, durch mehrere Anwendungen.
 

Bleiglanz

Gesperrter Benutzer
ich bin aber irgendwie auch der Meinung mit mehreren Java Anwendungen was zu lösen anstatt in einer mit mehreren inneren Klassen.
dann erklärs bitte:
1. Was meinst du mit "mehreren Java Anwendungen"?
2. Warum "innere Klassen" und nicht "normale Klassen"

Du redest vom Design, und schreibst dann über triviales: natürlich nimmt man bei Swing/AWT oft innere Klassen, aber das hat ja wenig mit der Situation zu tun

P.S.: Ich könnte mir z.B. Vorstellen, dass es eine serialisierbare Klasse ChatEintrag gibt, allein als Wrapper für String+Nickname, die zwischen den diversen Bauteilen hin und hergeschickt wird
 

m!k3

Bekanntes Mitglied
dann erklärs bitte:
1. Was meinst du mit "mehreren Java Anwendungen"?
2. Warum "innere Klassen" und nicht "normale Klassen"

Java-Anwendung is für mich eine eigene .java Datei
Normale Klasse ist für mich:

Code:
public class MeineNormaleKlasse
{
        public MeineNormaleKlasse()
        {
        }
}

Innere Klasse ist für mich:

Code:
public class MeineNormaleKlasse
{
        public MeineNormaleKlasse()
        {
        }    

        private class MeineInnereKlasse
        {
                public MeineInnereKlasse
                {
                }
        }
}


Hab vielleicht falsche Ausdrücke verwendet... hm... :oops:
 
B

Beni

Gast
Wobei guter Stil immer noch bedeutet: "pro Klasse eine Datei"... dein Konzept geht nicht auf :wink:
 

m!k3

Bekanntes Mitglied
ja.. versteht mich wohl falsch..

KeyListener is ja bezieht sich ja mehr auf die Datei als wie ein Frame beispielsweise.. warum den Frame nicht in ner eigenen Datei erstellen?!..
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
S OOP Problembereichsmodell: Bestehende Framework Klasse in eigene Klassenstruktur einbinden Allgemeine Java-Themen 9
G Klassenstruktur auslesen Allgemeine Java-Themen 2
D klassenstruktur gesucht Allgemeine Java-Themen 17
B Algorithmus für Arbeit mit fehlenden Listenelementen? Allgemeine Java-Themen 1
kodela Eingabe für TextArray bedingt sperren Allgemeine Java-Themen 3
Karl_Der_Nette_Anfänger Hat wer ne Lösung für verknüpfte Postleitzahlen? (Baum/Wurzel Struktur) Allgemeine Java-Themen 11
R 11 GB File lesen ohne zu extrahieren Filedaten Bereich für Bereich adressieren dann mit Multi-Thread id die DB importieren Allgemeine Java-Themen 3
G KeyListener für JTextField Allgemeine Java-Themen 5
webracer999 Library für Textsuche (z. B. include/exclude, and/or)? Allgemeine Java-Themen 5
I Module-Info für Jar erzeugen Allgemeine Java-Themen 7
krgewb Java-Bibliothek für ONVIF Allgemeine Java-Themen 1
B Simpler Eventlistener für Tastaturtaste bauen? Allgemeine Java-Themen 13
_user_q Eingegebenen Text Zeile für Zeile ausgeben lassen Allgemeine Java-Themen 11
E Key für TOTP Algorythmus(Google Authentificator) Allgemeine Java-Themen 0
S Formel für Sonnenwinkel in ein Programm überführen Allgemeine Java-Themen 11
M pfx-Zertifikat in Tomcat für SSL-Verschlüsselung nutzen Allgemeine Java-Themen 14
R Best Practice Erfahrungswerte für eine Migration von JSF nach Angular (oder anderes JS-Framework) Allgemeine Java-Themen 1
B HeapSort für Array of Strings funktioniert nur teilweise Allgemeine Java-Themen 3
jhCDtGVjcZGcfzug Klassen Was genau passiert hier? Kann mir das jemand bitte Zeile für Zeile erklären? Allgemeine Java-Themen 1
rosima26 Bester Sortieralgorithmus für kurze Arrays Allgemeine Java-Themen 40
S Mit Methoden kann man definieren für was <T> steht. Geht das auch irgendwie für Variablen? Allgemeine Java-Themen 12
MangoTango Operatoren while-Schleife für Potenz Allgemeine Java-Themen 3
B Lottospiel, genug Reihen tippen für 3 Richtige (Spaß mit Arrays)? Allgemeine Java-Themen 46
B Mit welchen Datentypen und Strukturierung am Besten dutzende Baccaratspiele Shcritt für Schritt durchsimulieren? Allgemeine Java-Themen 26
D Klassendesign für einen Pascal Interpreter Allgemeine Java-Themen 6
I OCR Library für Belegerkennung Allgemeine Java-Themen 7
farah GetterMathod für Farbkanäle Allgemeine Java-Themen 6
B Welcher Datentyp für sehr große Zahlenbereiche? Allgemeine Java-Themen 1
S Webservices für binäre Daten? Allgemeine Java-Themen 5
G Licence-Header für InHouse entwickelten Source Allgemeine Java-Themen 8
M Schleife für einen TicTacToe Computer Allgemeine Java-Themen 5
O git ignore für Intellji braucht es die .idea Dateien? Allgemeine Java-Themen 8
F Java Script für das Vorhaben das richtige? Allgemeine Java-Themen 9
M wiviel Java muss ich für die Berufswelt können ? Allgemeine Java-Themen 5
Robertop Datumsformat für GB ab Java 16 Allgemeine Java-Themen 1
Thallius Verschiedene entities für gleichen Code…. Allgemeine Java-Themen 8
OnDemand Zentrale "Drehscheibe" für verschiedene APIs Allgemeine Java-Themen 14
S Übergabe eines Sortierkriteriums für ein Artikel Array mittels BiPredicate<Artikel, Artikel> Allgemeine Java-Themen 13
F Streams als Alternative für dieses Problem ? Allgemeine Java-Themen 15
D SHA-3 für Java-version 1.8 Allgemeine Java-Themen 1
N Validator für einen SQL-Befehl Allgemeine Java-Themen 22
Muatasem Hammud Erstellung von Testdaten für Arrays Allgemeine Java-Themen 6
B Logikfehlersuche, das perfekte Lottosystem für 3 Richtige mit Arraylists? Allgemeine Java-Themen 61
G Methoden für die Zukunft sinnvoll? Allgemeine Java-Themen 4
M API für PLZ Umkreissuche Allgemeine Java-Themen 3
1Spinne JDK 8 für Eclipse installieren Allgemeine Java-Themen 5
Tobero Meine Funktion für das beinhalten eines Punktes in einem Kreis funktioniert nicht Allgemeine Java-Themen 5
L Methoden Parser für gängige Datumsformate? Allgemeine Java-Themen 1
H Interface PluginSystem ClassNotFound exception für library Klassen Allgemeine Java-Themen 10
N relativier Pfad für sqlite-Datenbank in Gradle/IntelliJ Allgemeine Java-Themen 2
buchfrau Anagram für beliebiges Wort Allgemeine Java-Themen 2
TonioTec Api für Datenaustausch zwischen Client und Server Allgemeine Java-Themen 0
W Suche Ursache für NPE - woher kommt sie? (Hilfe beim Debugging) Allgemeine Java-Themen 19
Kirby.exe Distanz Map für die Distanztransformation erstellen Allgemeine Java-Themen 1
F PI Regler für Heizung Allgemeine Java-Themen 7
8u3631984 Generelle Log4j.xml für alle Module Allgemeine Java-Themen 5
M Wie übergebe ich den Zähler für die Anzahl Rekursionsschritte korrekt? Allgemeine Java-Themen 2
B Login für User, der im Hintergrund Schedules ausführt Allgemeine Java-Themen 16
L RegEx für Teile einer Berechnung Allgemeine Java-Themen 14
S Java-Task-Management-Tool für Windows und Mac selber programmieren Allgemeine Java-Themen 4
M Java 2D Array für ein Grid erstellen ? Allgemeine Java-Themen 2
Z Welches GUI Framework für Java ist aktuell? Allgemeine Java-Themen 16
N Convert.FromBase64 von C# für Java Allgemeine Java-Themen 11
N fixed-keyword von C# für Java Allgemeine Java-Themen 6
O Suche Scripter für alt:V Project! Allgemeine Java-Themen 0
S Interface Design von HookUp oder Callback Methoden für eigenes Framework Allgemeine Java-Themen 9
O Suche Unterstützung für ein OpenSource-Projekt (grafischer Editor) Allgemeine Java-Themen 13
Kirby.exe Software für Graphische Visualisierung Allgemeine Java-Themen 20
B OOP Auslöser für NullPointerException Allgemeine Java-Themen 3
L Generator für einen Parser implementieren Allgemeine Java-Themen 13
DonMalte Ambitioniertes Projekt für Einsteiger & Motivierte Allgemeine Java-Themen 0
Kirby.exe Movement System für Spiel Allgemeine Java-Themen 13
Kirby.exe Framework für Game Design Allgemeine Java-Themen 8
W Alternative für Threads Allgemeine Java-Themen 6
S Rückgabe einer HttpURLConnection für eine Seite einlesen bei der man eingeloggt ist..? Allgemeine Java-Themen 5
Elyt Compiler-Fehler Datei kann nicht erstellt werden. Die Syntax für den Dateinamen etc. ist falsch. Allgemeine Java-Themen 2
Thallius Rätsel für Windows Profis Allgemeine Java-Themen 8
D OOP Gemeinsamen ID-Raum für zwei Klassen implementieren Allgemeine Java-Themen 7
D Input/Output Implementierung eines CommandHandlers/Parsers für viele Eingaben Allgemeine Java-Themen 26
Thallius Alternative für SwingWorker Allgemeine Java-Themen 5
I Lohnt sich heutzutage der Aufwand einer Portierung für MacOS Allgemeine Java-Themen 8
L Klassen Algorithmus für das folgende Problem entwickeln? Allgemeine Java-Themen 30
J Datenstruktur für eine Map erstellen Allgemeine Java-Themen 2
H OOP Setting(config) für Applikation sicheren? Allgemeine Java-Themen 9
OnDemand PDF Libary für Formulare Allgemeine Java-Themen 7
S Warmup für Lineare-Suche mit Zeitmessung Allgemeine Java-Themen 2
T Allgemeine Frage: GUI für 3D-Visualisierung Allgemeine Java-Themen 5
M Brainstorming für mein Projekt Allgemeine Java-Themen 30
K OOP Suche Hilfe + Erklärung für eine Hausaufgabe Allgemeine Java-Themen 1
F Was ist der Dateityp meines Parameters für die Main Methode. Allgemeine Java-Themen 6
C Bibliotheken für Algorithmische Geometrie Allgemeine Java-Themen 2
C Daten für Klassifikationsverfahren gewinnen Allgemeine Java-Themen 6
C code oder Bibliotheken für 2-Center Problem Allgemeine Java-Themen 4
I Overlay für Spiele Allgemeine Java-Themen 5
B Suche nach einem Testprogramm für meine BA Allgemeine Java-Themen 0
I GUI für kleine Pop-Ups unter Windows Allgemeine Java-Themen 1
A NetBeans Suche Programmierer für eine Belegarbeit Allgemeine Java-Themen 11
HarleyDavidson Best Practice Wohin mit der Konfigurationsdatei für Desktopapplikationen? Allgemeine Java-Themen 3
R MAC-Adresse eindeutig für einen PC ? Bezug zu Netzwerk, wieso ? Allgemeine Java-Themen 7
N Java API für CardDav und CalDav gesucht Allgemeine Java-Themen 4

Ähnliche Java Themen

Neue Themen


Oben