Kapselung Benutzerinterface für eine Liste

Leifa

Mitglied
Hallo,

ich programmiere zur Zeit ein kleines Programm und möchte es gerne "schön" programmieren, also OOP, Kapselung und Trennung von Programmlogik und GUI, damit mir das Ding nicht nach ein paar Wochen überm Kopf zusammenstürzt.

Zur Zeit beschäftigt mich diese Situation: Es gibt eine Klasse Programm mit einer Eigenschaft
Code:
private List<Person> personen = new ArrayList<Person>();
von Objekten meiner Klasse Person. Der Benutzer soll nun die Möglichkeit haben eine oder mehrere auszuwählen und soll dann seine Auswahl zurück an das Programm schicken. Wie ist nun der schönste Weg, diesen Vorgang umzusetzen? Ich habe mir mal verschieden Lösungen überlegt und würde gerne von erfahrenen Programmieren wissen, was am meisten Sinn macht.

1. Die Liste wird einfach public gemacht und ich gehe mit for(Person p: personen) die Liste durch. Beim Durchlaufen dieser Schleife lasse ich einen counter mitzählen, der sich den Index merkt. Der Nutzer wählt einige Personen aus, deren Indizes werden der Liste zum Löschen übergeben. (Problem: keine Kapselung? Die Liste sollte von außen nicht sichtbar sein.)

2. Die Liste bleibt private und es gibt eine Methode getListe(), die eine Kopie der Liste zurückgibt. Der Rest wie bei 1. (Problem: hoher Aufwand? und auch unnötige Informationen werden übergeben. Der Nutzer braucht eigentlich nur die Namen der Personen)

Auch beim Löschen von Elementen aus der Liste frage ich mich, sollten überhaupt die Indizes der gewählten Personen übergeben werden? Oder sollte das Objekt selbst übergeben werden? (ArrayList.remove macht beides möglich.)

Gibt es vielleicht noch weitere, schönere Wege?

Gruß
Leif
 

Gucky

Top Contributor
Variablen, egal ob Instanzen oder primitiv, müssen, laut OOP Konventionen, immer private sein (Außnahmen bestätigen die Regel).
Eigentlich ist der Sinn von OOP, dass es eine Klasse gibt, der gesagt wird: "Mach. Egal wie aber mach." Der Aufrufer will eigentlich nichts damit zu tun haben. Er will nur delegieren. Deshalb wäre das Zweite besser. Am Besten wäre es aber, du ließest die ArrayList in der Klasse, in der sie auch erstellt wird. Was, wenn du morgen eine LinkedList haben willst. Oder eine TreeMap? Dann musst du alles umschreiben.
 

kaoZ

Top Contributor
Wenn du Anwendungslogik von deinem GUI trennen willst schau dir mal das MVC, bzw MVP Pattern an , dort delegiert / Regelt ein Controller den Ablauf zwischen dem View und der Programmlogik, es so z.B auch möglich deine Logik je nach bedarf mit verschiedenen Controllern oder Views auszustatten.
 
Zuletzt bearbeitet:

lordofdonuts

Aktives Mitglied
Hallo Leifa,

"korrekt" wäre es, für die Klasse, die die ArrayList beinhaltet, erst mal ein Interface anzulegen.

Java:
public interface EditPersons
{
    public boolean addPerson(Person p);
    public boolean removePerson(Person p);
    public List<Person> choosePersons(int amount);
}

Dieses Interface muss von der Klasse Programm implementiert werden.

Java:
public class Programm implements EditPersons
{
    // ...
    @Override
    public boolean addPerson(Person p)
    {
        return persons.add(p);
    }

    @Override
    public boolean removePerson(Person p)
    {
        return persons.remove(p);
    }

    @Override
    public List<Person> choosePersons(int amount)
    {
        return persons.subList(0, amount);
    }
}

Wie du siehst, geht das ganz bequem mit der Methode subList. Möchtest du, dass die Methode choosePersons etwas anderes macht, kannst du das Interface EditPersons in einer anderen Klasse implementieren und die Logik nach deinen Wünschen umsetzen, z.B. könntest du eine choosePersons-Methode implementieren, die nur jede 2. Person zurückliefert.
In der aufrufenden Klasse benötigst du eine Variable vom Typ EditPersons und kannst je nach Bedarf ein Objekt einer implementierenden Klasse erzeugen. Das ganze nennt sich Polymorphie. :rtfm:

Generell sollte man aber bei kleineren Projekten den Code nicht so sehr "over-engineeren", da oft für wenig Wirkung ein ziemlicher bloat entsteht. Aber für Übungszwecke ist es in Ordnung.

Auch beim Löschen von Elementen aus der Liste frage ich mich, sollten überhaupt die Indizes der gewählten Personen übergeben werden? Oder sollte das Objekt selbst übergeben werden? (ArrayList.remove macht beides möglich.)

Nimm einfach das simplere - du könntest in meinem Beispiel für removePerson zwei verschiedene Varianten implementieren, wobei eine zuerst den Index rausrechnet und die andere direkt über das Objekt geht und schauen was passiert ;)
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
G Icon für App Java Basics - Anfänger-Themen 1
Kerstininer Vererbung Hilfe beim lernen von Objektorientierung für eine Klausur Java Basics - Anfänger-Themen 10
Sniper1000 Java 391 für Windows Java Basics - Anfänger-Themen 37
P Wieso kann ich als Index für einen Array einen Char angeben? Java Basics - Anfänger-Themen 3
benny1993 Java Programm erstellen für ein Fußball-Turnier Java Basics - Anfänger-Themen 3
V Durchschnittliche Volatility in Prozent für 4 Stunden berechnen Java Basics - Anfänger-Themen 14
P Welches SDK für das erstellen einer ausführbaren Datei? Java Basics - Anfänger-Themen 4
C negamax-Algorithmus für Tic-Tac-Toe spielt manchmal falsch Java Basics - Anfänger-Themen 10
D Apache HTTPClient für alle Fälle Java Basics - Anfänger-Themen 41
J Layout Manager, welcher ist der Richtige für mein Program? Java Basics - Anfänger-Themen 1
J Fehlermeldung unverständlich für Jakarta Java Basics - Anfänger-Themen 17
M Minimax-Algorithmus für Vier gewinnt Java Basics - Anfänger-Themen 11
M GUI für Vier-Gewinnt. Java Basics - Anfänger-Themen 4
I JPA Query für mehrere Klassen Java Basics - Anfänger-Themen 3
D Quellcode für cmd funktioniert nicht Java Basics - Anfänger-Themen 9
R Operatoren Rechenoperation in Java verwenden für Calculator Java Basics - Anfänger-Themen 2
R Operatoren Rechenoperation verwenden für Taschenrechner. Java Basics - Anfänger-Themen 32
Ostkreuz Counter für Booleanwerte Java Basics - Anfänger-Themen 8
B Regex Ausdrücke für Monate Java Basics - Anfänger-Themen 7
I BlueJ Queue Frage für Klausur Java Basics - Anfänger-Themen 2
K loop pausieren für eine bestimmte Anzahl? Java Basics - Anfänger-Themen 1
Jxhnny.lpz Randomisier für Buttons Java Basics - Anfänger-Themen 13
W Intuitive interface für Komponenten Java Basics - Anfänger-Themen 4
M "Class<T> clazz" im Constructor - auch für int möglich? Java Basics - Anfänger-Themen 7
B Schrankensystem mit Farberkennung für Flashgame funktioniert nicht wie geplant Java Basics - Anfänger-Themen 4
I Code für Bezahlsystem (auch bei Offline Aktivität) Java Basics - Anfänger-Themen 7
U jUnit 5 Test für eine addMethode Java Basics - Anfänger-Themen 18
M monte carlo Algorithmus für 4 gewinnt Java Basics - Anfänger-Themen 12
frager2345 Java Singleton Muster -> Methode für Konstruktor mit Parametern Java Basics - Anfänger-Themen 3
izoards Sortier Algorithmus für Bounding Box Elememte Links nach Rechts und von Oben nach Unten Java Basics - Anfänger-Themen 33
M generate Methode für Streams Java Basics - Anfänger-Themen 6
I Datenmodell für "Tags" Java Basics - Anfänger-Themen 6
Lion.King for-Kontrollstruktur für Pyramide Java Basics - Anfänger-Themen 8
B Mit Countdown Midnestdauer für Teilaufgabenerledigung erzwingen Java Basics - Anfänger-Themen 8
J File length als Prüfwert für Download Java Basics - Anfänger-Themen 5
K Spieleidee gesucht für Informatikprojekt - JAVA (BlueJ)? Java Basics - Anfänger-Themen 15
P Zähler Variable für mehrere Objekte Java Basics - Anfänger-Themen 6
javamanoman Java für Online Banking Java Basics - Anfänger-Themen 12
NadimArazi Wie kann ich eine collision detection für die Paddles in meinem Pong Programm hinzufügen? Java Basics - Anfänger-Themen 4
JordenJost Java ist auch eine Insel für Anfänger Java Basics - Anfänger-Themen 2
P9cman Tipps für Rekursive Aufgaben mit Strings oder allgemein Java Basics - Anfänger-Themen 2
F Suche nach betreuender Person für eine Jahresarbeit der 12. Klasse. Java Basics - Anfänger-Themen 6
I SQL / JPA Query für StartDate und EndDate Java Basics - Anfänger-Themen 1
T getMethode für ein Array Java Basics - Anfänger-Themen 2
Fats Waller Farben mixen für den Hintergrund ? Java Basics - Anfänger-Themen 1
H Suche jemanden für kleine Uni-Abgabe/ mit Vergütung Java Basics - Anfänger-Themen 1
K Für was braucht man die left und right shift operatoren? Was bringen die, also welchen Zweck haben die? Java Basics - Anfänger-Themen 15
N Api nur für Textdatein (.txt) Java Basics - Anfänger-Themen 2
bluetrix Programmieren eines Bots für Zahlen-Brettspiel Java Basics - Anfänger-Themen 9
M Wie kann eine Methode für ein vorhandenes "Array von char" einen Index-Wert zurückliefern? Java Basics - Anfänger-Themen 3
R Ist Java das Richtige für mich? Java Basics - Anfänger-Themen 4
E Mittelquadratmethode für Hexadezimalzahlen Java Basics - Anfänger-Themen 1
P Einfacher regulärer Ausdruck (RegEx) für E-Mail-Adressen Java Basics - Anfänger-Themen 2
Kiki01 Wie würde eine geeignete Schleife aussehen, die die relative Häufigkeit für jeden Charakter in einem Text bestimmt? Java Basics - Anfänger-Themen 3
N Fehler im Code (Aufgabe für Anfänger) Java Basics - Anfänger-Themen 11
O Wie erstelle ich eine Instanz in einer Klasse für die ich die Instanz will? Java Basics - Anfänger-Themen 4
S BubbleSort für ArrayLists Java Basics - Anfänger-Themen 3
T Übungsbuch für Anfänger Java Basics - Anfänger-Themen 3
L Konzept für Quiz Java Basics - Anfänger-Themen 33
D Methoden Plathhalter für Integer in einer Methode Java Basics - Anfänger-Themen 19
B Datentyp für Einzelnes Objekt oder Liste Java Basics - Anfänger-Themen 9
D Welche GUI Library für eine Client Server Chat App Java Basics - Anfänger-Themen 14
T Algorithmus für Index mit min-Wert Java Basics - Anfänger-Themen 2
Aqtox Hallo ich muss für die Schule ein Wuerfell Duell erstellen jedoch habe ich ein fehler Java Basics - Anfänger-Themen 4
L loop für Namen Java Basics - Anfänger-Themen 11
kxrdelis Konstruktor für ein Rechtwinkliges Dreieck Java Basics - Anfänger-Themen 10
S Fehler bei Code mit SubStrings für mich nicht auffindbar. Java Basics - Anfänger-Themen 4
nevel Programm für die Summer der Zahlen 1- 1ß Java Basics - Anfänger-Themen 12
I Entity erstellen, die für API gedacht ist Java Basics - Anfänger-Themen 33
C Archiv für eigene Klassen Java Basics - Anfänger-Themen 9
A Junit Test für MysqlDataSource JDBC Java Basics - Anfänger-Themen 3
Animal-Mother BMI Rechner erstellen für W/M Java Basics - Anfänger-Themen 7
E Kleines Java-Projekt für Anfänger Java Basics - Anfänger-Themen 10
A Java die richtige Programmiersprache für mein Projekt? Java Basics - Anfänger-Themen 1
I DecimalFormat in Zahlenformat für Währung, habe 7,99, bekomme aber 7 Java Basics - Anfänger-Themen 4
L Methode für Zweidimensionale Arrays Java Basics - Anfänger-Themen 4
Kanaska Datentyp für Zahlenbereiche Java Basics - Anfänger-Themen 7
T Startbildschirm für ein Spiel erstellen Java Basics - Anfänger-Themen 0
U BestPractise für Deployment unter Windows gesucht Java Basics - Anfänger-Themen 12
lilrack UML Diagramm für Parkplatzverwaltung Java Basics - Anfänger-Themen 8
W Mehrfach das gleiche Attribut für ein Objekt erzeugen (mit verschiedenen Werten) Java Basics - Anfänger-Themen 2
B Generische Typen für dynamisches Formular Java Basics - Anfänger-Themen 3
C Was ist nötig für ein Java-Programm auf Server für Website Java Basics - Anfänger-Themen 18
T Vererbung Verschiedene Attribute für vererbte Klassen Java Basics - Anfänger-Themen 4
T Start-Activity für Java Maven Web-Anwendung festlegen Java Basics - Anfänger-Themen 2
T Alternative für switch case Java Basics - Anfänger-Themen 1
P Ressourcen für JSON & API Informationen? Java Basics - Anfänger-Themen 1
M Java Einstellung von Apache POI für MS Word Erstellung mit Eclipse Java Basics - Anfänger-Themen 6
L Compiler-Fehler SupressWarning für clone() Java Basics - Anfänger-Themen 6
P Wie für EIN Java Programm von 64bit Java (=Standard) auf 32bit Java Installation (Windows) umschalten? Java Basics - Anfänger-Themen 6
B Methode für jede beliebe Entity erstellen Java Basics - Anfänger-Themen 7
D Ampel für Mitarbeiter zum An-/Abwesend zeigen Java Basics - Anfänger-Themen 28
T Wahrscheinlichkeiten für Slot Machine Java Basics - Anfänger-Themen 13
C Konvertierung des int typs in den double typ für die Ausgabe mit Nachkommastellen Java Basics - Anfänger-Themen 4
M Code nur für Cracks? Crack the Passwort Übung Java Basics - Anfänger-Themen 7
L Konstruktor für eine Map-Datei/Map-Datei einlesen Java Basics - Anfänger-Themen 5
T Roulette für Anfänger Java Basics - Anfänger-Themen 7
A Überprüfung für unentschieden in TicTacToe Java Basics - Anfänger-Themen 10
L Best Practice Code Refactoring für Methoden mit fast gleicher Aufbau Java Basics - Anfänger-Themen 6
J alternierendes Probing-Verfahren für Hash-Tabellen implementieren Java Basics - Anfänger-Themen 0

Ähnliche Java Themen

Neue Themen


Oben