OOP Generelle Frage zu Objekten in Arrays

Alan47

Mitglied
Hallo zusammen,

ich bin noch relativ neu im Bereich der objektorientierten Programmierung und ich habe grade ein Problem, bei dem ich wirklich anstehe. Es geht hier nicht um eine lange Implementierung, sondern nur um eine einzige Zeile.


Folgendes Problem: Nehmen wir an, wir würden eine Klasse "Einkaufskorb" schreiben. Wir haben weiters eine Klasse "Waren". "Waren" hat diverse von ihr abgeleitete Kinderklassen wie "Obst", "Elektronik" etc.

So weit, so gut. Ich möchte jetzt in meiner Klasse "Einkaufskorb" ein Feld namens "Inhalt" haben, das ein Array fixer Größe sein soll, und Referenzen auf "Waren"-Objekte enthalten soll. Es soll aber nicht nur "Waren"-Referenzen enthalten können, sondern auch Referenzen auf die Kindklassen von "Waren" aufnehmen können. So sollte beispielsweise Inhalt[0] eine Referenz auf ein Objekt der Klasse "Obst" sein können, Inhalt[1] eine Referenz auf ein Objekt der Klasse "Elektronik" etc.


Die große Frage ist: wie definiere ich so ein Array bzw. Feld in Java? Oder bin ich hier komplett am Holzweg und mein Ansatz ist so gar nicht durchführbar?


Gruß,


Alan



PS: Nein, das hier ist keine Hausaufgabe oder sonstiges (auch wenn mein Beispiel vielleicht so klingt ;)). Ich mache das aus persönlichem Interesse und weiß hier nicht weiter ^^'
 

Alan47

Mitglied
Echt??? ô.o

So einfach? Aber wenn von der Klasse "Waren" etwas abgeleitet wird, dann ist ja die abgeleitete Klasse vom Platzbedarf im RAM her ja "größer", weil sie alles von der Mutterklasse erbt - plus das, was sie selber an Feldern und Methoden hat. Müsste dann auch nicht der Pointer auch entsprechend mehr Platz verbrauchen?
 
L

lollal

Gast
Das ist am Anfang etwas Tricky. Dein "Pointer" lässt dich nur auf Member zugreifen, die in Waren definiert sind. Wenn du in deinem Array also ein Elektronikartikel hast, welcher erstmal die Methode zeigeWatt() implementiert, kannst du darauf nicht zugreifen da deine Klasse Waren eben keine zeigeWatt()-Methode besitzt. Der Pointer bleibt der gleiche.
 

Alan47

Mitglied
Also die Pointer, die dann im Waren-Array drin stehen, können dann nur auf den Teil der Objekte zugreifen, der wirklich direkt in der "Waren"-Klasse definiert wurde, sehe ich das richtig?

Falls ja: gibt es trotzdem irgendeinen Weg, über diesen Pointer auch auf die Felder und Methoden (wie zum Beispiel die zeigeWatt()-Methode von dir) der Kindklassen zuzugreifen? Immerhin referenziert der Pointer das gesamte Objekt und nicht nur einen Teil davon - soweit ich weiß zumindest.


PS: Danke für die Hilfe bisher!!
 
L

lollal

Gast
Wie das technisch genau abläuft muss dir besser wer anders erklären, wäre sonst eher kontraproduktiv wenn du was lernen willst :)

Aber nein, aus deinem Waren-Array heraus kannst du nicht auf Subklassenspezifische Methoden zugreifen. Es sei denn, du castet es beim Aufrufen in den entsprechenden Typ.
Auch wenn dich das jetzt evt stört: wenn du genau nachdenkst, gibt es überhaupt keinen Grund auf subklassenspezifische Dinge über das Array zuzugreifen. In der Waren-Klasse oder per Interfaces kannst du ja Methoden festlegen, die aufrufbar sein müssen, zum Beispiel eine getInfo-Methode. Darin könntest du einen String o.ä. zurückliefern, welcher Objektspezifische Dinge wie die Wattzahl oder die Vitamine eines Obststücks zurückliefert.

Bedenke: deine Objekte im Array sind voll funktionstüchtig mit all ihren spezifischen Eigenheiten, du kannst nur nicht über das Array vom Typ Waren auf spezifische Dinge zugreifen.
 

Alan47

Mitglied
Auch wenn dich das jetzt evt stört: wenn du genau nachdenkst, gibt es überhaupt keinen Grund auf subklassenspezifische Dinge über das Array zuzugreifen.

Hm bei mir eben genau schon xD Wie du dir vielleicht gedacht hast, ist das Beispiel oben nur eine "Verallgemeinerung" dessen, was ich hier wirklich mache. Die Basis-Klasse (hier: "Waren") ist bei mir nicht sehr umfangreich, da sich die Gemeinsamkeiten der "Kinderklassen" auf ein Minimum beschränken.

Allerdings habe ich nur drei verschiedene "Kinderklassen" von "Waren" - wäre es vielleicht klüger, für jede dieser Kindklassen ein eigenes Objekt-Array vom Typ der jeweiligen Kindklasse anzulegen, um dann Vollzugriff auf all ihre Felder und Methoden zu haben? Es ist für mich nicht weiter von Bedeutung, ob alle Objekte in einem Array stecken oder in drei verschiedenen nach Typ sortiert. Der "Warenkorb" ist ja praktisch nur ein "Container". Aber wenn man es so macht, dass man - hier im Beispiel jetzt - drei Kindklassen hat und damit 3 Arrays vom Typ der jeweiligen Kindklasse aufstellt (ein Array für "Obst", eines für "Elektronik" und ein drittes für "Tiernahrung"), dann haben die Pointer, die in diesen Arrays enthalten sind, schon Zugriff auf die Felder und Methoden, die die Objekte von "Waren" geerbt haben, oder?
 
Zuletzt bearbeitet:

Landei

Top Contributor
Es gibt einfach einen Unterschied zwischen dem statischen Typ einer Referenz (in Java spricht man nicht von "Pointern") und dem tatsächlichen Typ, auf dem die Referenz zeigt. Du kannst z.B. Sachen schreiben wie
Java:
CharSequence cs = "Bla";
Serializable s = "Foo";
Collection<Date> coll = new HashSet<Date>();

In der Regel versucht man so "allgemein" oder "aufgabenbezogen" zu bleiben wie möglich. Manchmal ist der genaue Typ unwichtig, sondern nur, ob du das Objekt serialisieren kannst. Manchmal reichen die Operationen von CharSequence aus, und du brauchst keinen String. Falls du doch an den "richtigen" Typ heranmusst, gibt es immer noch instanceof-Tests und Casts.
 

Wortraum

Bekanntes Mitglied
Echt??? ô.o

So einfach?
Ja, erschreckend, nech? :) Elektronik, Obst, Bücher sind alles Waren (erben davon) und können somit alles, was eine Ware kann. Es ist daher immer erlaubt, sie einer Variable vom Typ Ware zuzuweisen.
Code:
Ware ware = new Elektronik();
/* Was Ware kann, kann Elektronik schon lange! */

Aber wenn von der Klasse "Waren" etwas abgeleitet wird, dann ist ja die abgeleitete Klasse vom Platzbedarf im RAM her ja "größer", weil sie alles von der Mutterklasse erbt - plus das, was sie selber an Feldern und Methoden hat. Müsste dann auch nicht der Pointer auch entsprechend mehr Platz verbrauchen?
Das braucht er sicherlich, aber die Speicherüberwaltung übernimmt Java, da muß man sich nicht drum kümmern.

Allerdings habe ich nur drei verschiedene "Kinderklassen" von "Waren" - wäre es vielleicht klüger, für jede dieser Kindklassen ein eigenes Objekt-Array vom Typ der jeweiligen Kindklasse anzulegen, um dann Vollzugriff auf all ihre Felder und Methoden zu haben?
Dir geht nie etwas verloren, wenn Du ein Objekt Elektronik in ein Feld für Waren-Objekte steckst. Wenn Du das Objekt allerdings wieder aus dem Feld mit Waren holst, ist es erst einmal nur als ein Waren-Objekt bekannt. Es ist ein bißchen wie mit einem großen Korb, wo jeder erst einmal was reinschmeißt; greift man dann rein, weiß man erst einmal nur, daß man eine Ware hat, und erst, wenn man sie sich genauer anschaut, sieht man, was es wirklich ist und was man damit spezielles machen kann.
Code:
List<Ware> korb = new ArrayList<Ware>();
… /* Korb füllen */
Ware eineWare = korb.get(0);
if (eineWare instanceof Elektronik) {
    /* aha, eineWare ist nicht nur Ware, sondern ganz speziell ein Objekt Elektronik */
    /* na gut, dann können wir es ja wie Elektronik behandeln und dazu umwandeln */
    Elektronik elektro = (Elektronik) eineWare;
    … /* mache irgend etwas mit elektro, was mit eineWare nicht geht */
}

Bleibt noch die Frage, ob man nun besser einen großen Warenkorb macht, in den man erst einmal alles reinschmeißt, oder ob man für jede Kategorie einen eigenen Korb macht. Das hängt wohl davon ab, was man so spezielles machen will und muß. Einerseits will man nicht überall prüfen, was für eine Ware man gerade hat, andererseits hätte man auch gerne einen einzigen Warenkorb und nicht viele kleine für unterschiedliche Waren.

Es könnte für jede Ware beispielsweise ein Info-Objekt geben mit Haltbarkeitsdatum, Garantiezeit oder Wattzahl, und nur die benötigten Angaben sind ausgefüllt. Dann könnte jede Ware eine Methode getInfo() haben, und man müßte nicht mehr auf Elektronik oder Obst prüfen.

Mir persönlich gefällt es nicht, einen Warenkorb noch einmal zu unterteilen und später aus den Teilen dann einen Gesamtpreis zu errechnen oder was auch immer, also kurz: irgendwann die Teile wieder als ganzes zu behandeln. Wenn es sich also vermeiden läßt oder nicht anderes dagegen spricht, würde ich einen Warenkorb für alle Waren machen.
 

Alan47

Mitglied
Code:
Ware ware = new Elektronik();
/* Was Ware kann, kann Elektronik schon lange! */

Das braucht er sicherlich, aber die Speicherüberwaltung übernimmt Java, da muß man sich nicht drum kümmern.

Na die Einstellung gefällt mir ;)



Dir geht nie etwas verloren, wenn Du ein Objekt Elektronik in ein Feld für Waren-Objekte steckst. Wenn Du das Objekt allerdings wieder aus dem Feld mit Waren holst, ist es erst einmal nur als ein Waren-Objekt bekannt. Es ist ein bißchen wie mit einem großen Korb, wo jeder erst einmal was reinschmeißt; greift man dann rein, weiß man erst einmal nur, daß man eine Ware hat, und erst, wenn man sie sich genauer anschaut, sieht man, was es wirklich ist und was man damit spezielles machen kann.
Code:
List<Ware> korb = new ArrayList<Ware>();
… /* Korb füllen */
Ware eineWare = korb.get(0);
if (eineWare instanceof Elektronik) {
    /* aha, eineWare ist nicht nur Ware, sondern ganz speziell ein Objekt Elektronik */
    /* na gut, dann können wir es ja wie Elektronik behandeln und dazu umwandeln */
    Elektronik elektro = (Elektronik) eineWare;
    … /* mache irgend etwas mit elektro, was mit eineWare nicht geht */
}

Ach SO, jetzt habe ich es begriffen! Ich kann bei diesen Referenzen dann praktisch nachprüfen, zu welcher Kindklasse von Waren sie tatsächlich gehören und dann quasi einen Typecast mit der Referenz auf die tatsächliche Kindklasse machen - ja das macht Sinn!


Einerseits will man nicht überall prüfen, was für eine Ware man gerade hat, andererseits hätte man auch gerne einen einzigen Warenkorb und nicht viele kleine für unterschiedliche Waren.

Genau diese Frage hat sich mir auch aufgedrängt - ich glaube ich werde jetzt doch nur ein Array machen und bei bedarf deine Lösung von oben mit dem Typecast anwenden.



Jungs, vielen vielen Dank für eure Hilfe, mir ist jetzt einiges klarer als vorher!!


Besten Dank,



Alan
 
B

bygones

Gast
wobei solche instanceof tests und dann folgende casts sehr zu bedenken sind... gibt meist immer eine elegantere und schoenere loesung !

also lieber finger weg von instanceof abfragen
 

Wortraum

Bekanntes Mitglied
Aber es gibt Ansätze, Ideen und Möglichkeiten. Die konkrete Lösung muß man meistens dem eigenen Wissenstand entsprechend selbst ertüfteln, und meistens fehlt nur der Ansatz.

Richtig ist wohl, daß es fast immer eine schönere und elegantere Lösung gibt, sofern man nicht schon Experte ist. :)
 

Alan47

Mitglied
Richtig ist wohl, daß es fast immer eine schönere und elegantere Lösung gibt, sofern man nicht schon Experte ist. :)

... und der bin ich in Java noch lange nicht ;) Bin ersmtal froh, wenn ich vernünftig damit arbeiten kann und mein Programm halbwegs so funktioniert, wie ich mir das vorstelle - nachher denke ich mir dann eh meistens "Das wäre noch besser gegangen wenn..." aber nur so lernt man wirklich dazu glaube ich ;)


Gruß,



Alan
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
I Generelle Frage zu Mikroservices (Spring Boot?), Docker... Java Basics - Anfänger-Themen 7
G generelle Frage zu Strukturierung von Java-Programmen Java Basics - Anfänger-Themen 2
I Generelle Frage zu Interface Java Basics - Anfänger-Themen 3
I REST Api / JAX-RS, Swagger (OpenAPI) - generelle Starthilfen benötigt Java Basics - Anfänger-Themen 15
B Erste Schritte Generelle Fragen zu Java / Greenfoot. Java Basics - Anfänger-Themen 8
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 Verständnis Frage zu Variablen Java Basics - Anfänger-Themen 3
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
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
S Verständnis-Frage zu einer HÜ? Java Basics - Anfänger-Themen 1
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
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

Ähnliche Java Themen

Neue Themen


Oben