Grundsätzliche Klassen-Struktur/Stil

blz

Bekanntes Mitglied
Hi,
ich hätt mal eine grundsätzliche (Stil)Frage:

Wenn ich ein Projekt entwickel, wo ich in verschiedenen Klassen immer wieder die gleichen Methoden verwende, zB public (static) int countXY() - erstell ich dann am Besten eine Klasse, zB PermanentNeededMethods und schreib die da rein?
Und wenn ich sie benutzen will? Erstell ich dann in jeder anderen Klasse ein PermanentNeededMethods Objekt? Oder schreib ich dann PermanentNeededMethods.countXY()?
Also vllt klingt die Frage bisschen komisch aber ich will mir ja nen guten Stil angewoehnen :)
 

langhaar!

Bekanntes Mitglied
Wenn du von PermanentNeededMethods ein Objekt instanziierst, dann macht es keinen Sinn, dass deine Methoden statisch sind. Eclipse warnt in dem Fall sogar.

Ich würde die statischen Methoden in Aufgabenbereiche trennen und in Klassen packen, so dass am Klassennamen erkennbar ist, zu welchem Bereich die Methoden gehören. Ein PermanentNeededMethods.countXY() sagt gar nichts.
 

darekkay

Bekanntes Mitglied
Typisch sind Klassen(namen) wie StringUtil, NumberUtils, DateTimeUtils etc. Wie langhaar es schon sagte: einfach nach Themengebieten trennen. Und wenn diese Klassen zu groß werden (~500+ Zeilen), solltest du sie weiter unterteilen (z.B. DateTimeUtils -> DateUtils + TimeUtils).
Solche Hilfsmethoden sind dann so gut wie immer statisch (musst du wirklich ein Objekt deiner StringUtil-Klasse erzeugen, um alle Zeichen eines Strings zu zählen?).
 

blz

Bekanntes Mitglied
@langhaar!
es geht mir eigentlich nicht drum ob die statisch ist oder nicht. (daher in klammern)
und dass PermanentNeededMethods.countXY() nicht viel aussagt ist schon klar, hab ich jetzt hier halt mal so genannt.
es geht mir um die grundsätzliche struktur.
pack ich die dinger in ne eigene klasse und erzeuge ich ein objekt davon und sprech sie via objekt an?
was ja irgendwie - soweit ich das verstanden hab - nicht ganz im sinne der klassischen objektorientierung wäre, wo man objekte des realen lebens abbildet und diese kommunizieren laesst. - schon klar, dass man nicht immer nur echte dinge abbildet, aber einfach ein objekt von ner hilfsklassen klasse fand ich eben bisschen komisch. daher die frage.
andre möglichkeit, die klasse statisch zu machen und dann via klassenname.methode() ansprechen. aber wahrscheinlich auch komisch...(?)

@darekkay
ok, also kein schlechter stil ne klasse zu erstellen wo 10 kleine statische hilfsmethoden drinstecken?
und wie sprech ich sie dann an?
 
B

bygones

Gast
Gibt es dafür wichtige Gründe, oder einfach nur, damit sie nicht zu unübersichtlich werden?

reicht dir dieser Grund nicht aus ?

grob generell gesagt sollte man sich bei solchen Ueberklassen diese sich nochmals genau anschauen. Die Gefahr ist dass sie zu viel machen, also zu viele Verantwortlichkeiten haben und man sie daher besser modularisieren sollte (Single responsibility principle - Wikipedia, the free encyclopedia)

@darekkay
ok, also kein schlechter stil ne klasse zu erstellen wo 10 kleine statische hilfsmethoden drinstecken?
und wie sprech ich sie dann an?
nein ueberhaupt nicht, wenn diese statischen hilfsmethoden wirklich klein sind und nicht noch weitere Abhaengigkeiten haben, erstellen oder nutzen ist dies wesentlich besser als code duplikationen ueberall in seinem Projekt zu haben.
Ein bsp wann eine statische Methode nicht sehr gut ist, ist:
Java:
// in irgendeiner klasse
public void foo() {
  Database.connect();
  // do something
}

public final class Database {
  private Database() {
    // static
  }

  // bsp
  public static void connect() {
    DatabaseConnection con = new DatabaseConnection();
    con.connectToProductiveDatabase();
  }
}
hier macht die statische Methode mehr als sie sollte. Von deinem code aus gibt es nun keine moeglichkeit nicht zur produktiven Db zu connecten - du kannst die Abhaengigkeit nicht injecten (argh so viel denglische begriffe).
Simple gute bsp fuer statische Hilfsmethoden -> java.lang.Math
 
Zuletzt bearbeitet von einem Moderator:
S

Spacerat

Gast
Typisch sind Klassen(namen) wie StringUtil, NumberUtils, DateTimeUtils etc. Wie langhaar es schon sagte: einfach nach Themengebieten trennen. Und wenn diese Klassen zu groß werden (~500+ Zeilen), solltest du sie weiter unterteilen (z.B. DateTimeUtils -> DateUtils + TimeUtils).
Solche Hilfsmethoden sind dann so gut wie immer statisch (musst du wirklich ein Objekt deiner StringUtil-Klasse erzeugen, um alle Zeichen eines Strings zu zählen?).
Mal so am Rande... Was ist denn an java.lang.Math und (z.B.) java.awt.Toolkit auszusetzen, dass man auf die Idee kommt, sich immer irgendwelche XUtils Klassennamen aus den fingern zu saugen? Naja, nun hast dir die Mühe gemacht, aber für's nächste Mal... ;)
Das wäre im übrigen dann noch eine andere Möglichkeit der Namensgebung für Utility- bzw. Toolkit-Klassen - Bestimmt durch die Lage in der Pakethierarchie.
[EDIT]Zu langsam Spacerat! ...nehmt's mir net übel, man wird älter. XD[/EDIT]
 

blz

Bekanntes Mitglied
@bygones:
sorry, versteh das bsp nicht ganz. wo ist die statische methode? und was ist ne produktive db und was heisst injecten?
 
B

bygones

Gast
sorry hatte static vergessen ;-)

wenn dir die Begriffe sonst nix sagen, dann vergiss meinen post einfach erstmal. Sie werden dir noch in deiner Laufbahn vorkommen.
 

darekkay

Bekanntes Mitglied
Mal so am Rande... Was ist denn an java.lang.Math und (z.B.) java.awt.Toolkit auszusetzen, dass man auf die Idee kommt, sich immer irgendwelche XUtils Klassennamen aus den fingern zu saugen? Naja, nun hast dir die Mühe gemacht, aber für's nächste Mal... ;)
Das wäre im übrigen dann noch eine andere Möglichkeit der Namensgebung für Utility- bzw. Toolkit-Klassen - Bestimmt durch die Lage in der Pakethierarchie.

Bemängelst du die Hilfsklassen selbst oder die Namensgebung XUtil(s)? Für das erste: es gibt Hilfmethoden, die ich brauche, die es aber so noch nicht implementiert gibt. Da dir das sicherlich auch bewusst ist, meinst du wohl das zweite. Die Frage ist - was spricht dagegen, den Klassennamen mit Util zu beenden? Der Name soll doch genau beschreiben, was eine Klasse macht. StringUtil(ities) tut genau das: es beinhaltet Hilfmethoden zum Umgang mit Strings. Apache nutzt selbst eine StringUtils-Klasse, warum auch nicht?

Und was gibt's an Math und Toolkit auszusetzen? Fangen wir mit den 1500 bzw. 2500 Zeilen Code an ;)
Gleiches wird früher oder später jeder StringUtil-Klasse passieren, weswegen man wie erwähnt Code auslagern sollte.
 
S

Spacerat

Gast
Bemängelst du die Hilfsklassen selbst oder die Namensgebung... ?
Ich bemängele gar nichts von beiden. Nur wenn man Threads in denen es um solche Klassen geht, beantwortet, überlegt man sich zum Text erst immer irgendwelche (so 6, 8 bis 2) dubiose Namen wie ImageUtils, AudioUtils, meinetwegen noch... ach, da fällt mir jetzt nix mehr ein. Dabei gibt es doch so viele bereits vorhandene Hilfsklassen, deren Namen und Inhalt auch vollkommen berechtigt sind. Irgendwann ist im übrigen in jeder Hilfsklasse mit "Auslagern von Code" schluss. Man fängt in kleinen logisch zusammenhängenden Einheiten an und in naher Zukunft kommen ohnehin zig neue Methoden hinzu, weil sie halt in diesen logischen Zusammenhang passen. Dann hat auch die am besten geplante Hilfsklasse 2000 Zeilen Code.
 
Zuletzt bearbeitet von einem Moderator:

darekkay

Bekanntes Mitglied
Ich bemängele gar nichts von beiden. Nur wenn man Threads in denen es um solche Klassen geht, beantwortet, überlegt man sich zum Text erst immer irgendwelche (so 6, 8 bis 2) dubiose Namen wie ImageUtils, AudioUtils, meinetwegen noch...

Aaachso, ja, da geb ich dir recht, hab nicht an die typischen Hilfsklassen gedacht ;)
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
J Grundsätzliche Frage zu return Types in Methoden Java Basics - Anfänger-Themen 6
DStrohma Grundsätzliche Fragen zu Drag & Drop Java Basics - Anfänger-Themen 1
S Grundsätzliche Programmstruktur planen Java Basics - Anfänger-Themen 5
C Grundsätzliche Fragen zu Objekten Java Basics - Anfänger-Themen 6
F Grundsätzliche Frage zu GUI's. Java Basics - Anfänger-Themen 5
W Gui - Grundsätzliche Programmierung Java Basics - Anfänger-Themen 11
M Grundsätzliche Fragen Java Basics - Anfänger-Themen 3
J Grundsätzliche Fragen zur Anwendung von Applets Java Basics - Anfänger-Themen 12
J Methodenaufrufe abstrakte Klassen, Interfaces Java Basics - Anfänger-Themen 17
M Abstrakte Klassen - Notation Java Basics - Anfänger-Themen 9
Detlef Bosau Nachladen von Klassen zur Laufzeit Java Basics - Anfänger-Themen 24
M Anonyme Klassen - Warum wird in der Konsole nichts ausgegeben? Java Basics - Anfänger-Themen 1
MoxMorris Einige Methoden aus verschiedenen Klassen nacheinander auszuführen läuft seltsam Java Basics - Anfänger-Themen 2
I Klassen von einem package laden, Statisches Feld auslesen und Objekt erstellen Java Basics - Anfänger-Themen 8
I 2 verschiedene Klassen mit gleichen Property vergleichen Java Basics - Anfänger-Themen 13
C Array von Klassen Java Basics - Anfänger-Themen 2
monsterherz 2 Klassen daher Probs mit dem Dateinamen Java Basics - Anfänger-Themen 9
C Kommunikation zwischen 2 Klassen Java Basics - Anfänger-Themen 9
I JPA Query für mehrere Klassen Java Basics - Anfänger-Themen 3
I @Entity Klassen, Service Beans etc. aus einem Share Projekt beziehen? Java Basics - Anfänger-Themen 26
S IntelliJ geht alle Klassen durch Java Basics - Anfänger-Themen 9
I Gleiche Klassen und Methoden in unterschiedlichen Projekten nutzen Java Basics - Anfänger-Themen 2
T variablen klassen übergreifend Java Basics - Anfänger-Themen 12
N Klassen Methoden anderer Klassen aufrufen Java Basics - Anfänger-Themen 4
D Klassen Klassen Kommunikation Java Basics - Anfänger-Themen 12
Encera Auf Objekte aus anderer Klassen zugreifen Java Basics - Anfänger-Themen 20
berserkerdq2 Zwei Klassen Erben von der Klasse A, die eine Klasse kann ich an Methoden übergeben, die als Parameter A haben, die andere nicht? Java Basics - Anfänger-Themen 3
M Andere Methoden in anderen Klassen aufrufen Java Basics - Anfänger-Themen 11
L Methoden in anderen Klassen nutzen Java Basics - Anfänger-Themen 6
D Klassen und Vererbung Java Basics - Anfänger-Themen 2
L Best Practice Annotierte Klassen im Classpath herausfinden Java Basics - Anfänger-Themen 1
P Mit dem Scanner Klassen aufrufen Java Basics - Anfänger-Themen 3
O Klassen Zusammenspiel zwischen 2 Klassen Java Basics - Anfänger-Themen 1
K Zweite Ausgabe von vererbten Klassen Java Basics - Anfänger-Themen 3
M Wie können Klassen nicht-materialisierte Attribute haben, die nur über get/ set-Mehoden simuliert sind? Java Basics - Anfänger-Themen 6
Speedrunner klassen aufrufen Java Basics - Anfänger-Themen 41
M Log4J (v2) nachträglich in allen Klassen hinzufügen Java Basics - Anfänger-Themen 9
D importieren eigener Klassen Java Basics - Anfänger-Themen 12
W Wo ist der Wurm in meinem Grundverständnis von Klassen? Java Basics - Anfänger-Themen 22
S Daten/Klassen/Packages richtig updaten!? Java Basics - Anfänger-Themen 2
alice98 Erste Schritte Liste erstellen ohne vorgefertigte Klassen Java Basics - Anfänger-Themen 1
C Archiv für eigene Klassen Java Basics - Anfänger-Themen 9
S Objekte von zwei klassen in zwei verschiedene Textdateien schreiben Java Basics - Anfänger-Themen 5
elsaaaaaa Wochentag als String ausgeben mit JDK Klassen Java Basics - Anfänger-Themen 6
CptK Generics: Klassen die Interface implementieren, aber selbst nicht das Interface sind Java Basics - Anfänger-Themen 8
Z Mehtode bei Start des Programms ausführen (Klassen übergreifend) Java Basics - Anfänger-Themen 12
J Allgemeines Problem mit Klassen Java Basics - Anfänger-Themen 5
TimoN11 Java Klassen Global einbinden Java Basics - Anfänger-Themen 1
B Inventar als einzelne Klassen anlegen? Java Basics - Anfänger-Themen 12
G Java Klassen und Instanzmethoden Java Basics - Anfänger-Themen 15
C Kommunikation zwischen 2 Klassen Java Basics - Anfänger-Themen 3
T Vererbung Verschiedene Attribute für vererbte Klassen Java Basics - Anfänger-Themen 4
S Klassen instanziieren und verwenden von Getter und Setter Java Basics - Anfänger-Themen 4
B Variablen Variablen übertragen ohne Klassen Java Basics - Anfänger-Themen 5
C Fernseher-Aufgabe (Methoden, Klassen und Objekte) Java Basics - Anfänger-Themen 63
H Methoden in großen Klassen gruppieren oder auslagern? Java Basics - Anfänger-Themen 10
G Abstrakte Klassen Java Basics - Anfänger-Themen 11
Y Klassen Klassen und Objekte Java Basics - Anfänger-Themen 3
Y Klassen Klassen und Objekte mit set und get Java Basics - Anfänger-Themen 0
A Generischen Klassen Java Basics - Anfänger-Themen 8
A Vererbung Klassen im Bezug auf Auto´s Java Basics - Anfänger-Themen 18
A Generische Klassen/Interface Java Basics - Anfänger-Themen 1
A Klassen Vererbung und zusätzliche Unterklassen Java Basics - Anfänger-Themen 23
J 2 klassen benutzen Java Basics - Anfänger-Themen 5
A Klassen und methoden Java Basics - Anfänger-Themen 15
A Bankweverwaltung mit Klassen und Methoden Java Basics - Anfänger-Themen 14
J Klassen Problem Java Basics - Anfänger-Themen 8
I Java Klassen "Graphics" und "MouseEvent" kombinieren Java Basics - Anfänger-Themen 7
I Klassen als Datentyp nutzen? Java Basics - Anfänger-Themen 11
M Aufsplitten von Methoden in andere Klassen Java Basics - Anfänger-Themen 2
M (Sehr großes Problem) Listen als static in anderen Klassen verwendet Java Basics - Anfänger-Themen 12
C Klassen objektorientiert aufteilen Java Basics - Anfänger-Themen 6
hello_autumn Klassen Anzahl sowie die Anzahl der Junit Tests ermitteln? Java Basics - Anfänger-Themen 8
A Auf Eigenschaften von Objekten anderer Klassen zugreifen Java Basics - Anfänger-Themen 5
F Klassen und Pakete Projektübergreifend (Eclipse) Java Basics - Anfänger-Themen 6
V_Fynn03 Klassen Überweisungen tätigen und einzahlen mit 2 Klassen Java Basics - Anfänger-Themen 1
W Abarbeitungsreihenfolge Anonyme Klassen Java Basics - Anfänger-Themen 2
V_Fynn03 Bruchrechner programmieren (2 Klassen) Java Basics - Anfänger-Themen 9
D OOP- Eine Klasse in mehrere Klassen aufteilen Java Basics - Anfänger-Themen 7
J Problem mit Array: 2 Klassen Java Basics - Anfänger-Themen 2
W Frage zu anonymen Klassen Java Basics - Anfänger-Themen 4
Curtis_MC Parameter-Übergabe bei Klassen und Methoden Java Basics - Anfänger-Themen 12
E Klassen implementieren Java Basics - Anfänger-Themen 94
T Interfaces in erbenden Klassen Java Basics - Anfänger-Themen 2
C Methoden/Klassen Übergabewerte Java Basics - Anfänger-Themen 8
C Java Klassen/Methoden/Übergabeparameter Java Basics - Anfänger-Themen 4
L Wie geht man bei mehreren Action Klassen vor? Java Basics - Anfänger-Themen 0
P Datentypen, Klassen, Operatoren, Wrapperklassen Java Basics - Anfänger-Themen 2
L Wie teilt man ein Programm in vernünftige Klassen ein? Java Basics - Anfänger-Themen 10
T Klassen Denkfehler im Klassen "dynamisch" instanzieren? Java Basics - Anfänger-Themen 4
P Zugriff auf Variablen anderer Klassen in Greenfoot Java Basics - Anfänger-Themen 1
A Methode, Klassen Java Basics - Anfänger-Themen 3
B UML Klassen Diagramm zu Java Code Programmieren und ausführen Java Basics - Anfänger-Themen 21
J Zwei Klassen die sich gegenseitig referenzieren - Bad practice? Java Basics - Anfänger-Themen 4
G Klassen und Objekte Java Basics - Anfänger-Themen 2
Java The Hutt SetWerte über verschiedene Klassen Java Basics - Anfänger-Themen 16
D Klassen ausgeben Java Basics - Anfänger-Themen 2
H linkedlist generische klassen Java Basics - Anfänger-Themen 169
B CSS Klassen in eine Liste schreiben Java Basics - Anfänger-Themen 4
Queiser Nicht statische Klassen Java Basics - Anfänger-Themen 6

Ähnliche Java Themen

Neue Themen


Oben