Objektorientierte Programmierung
LVA 185.162, VL 2.0, 2008 W
9. Übungsaufgabe
Themen:
Entwurfsmuster, Untertypbeziehungen, gesamter Stoff
Termine:
| Ausgabe: |
11.12.2008, 12:45 Uhr |
| reguläre Abgabe: |
18.12.2008, 12:45 Uhr |
| nachträgliche Abgabe: |
15.01.2009, 12:45 Uhr |
Abgabeverzeichnis:
Gruppe/Aufgabe9
Programmaufruf:
java Test
Grundlage:
Skriptum bis Seite 161 und Seite 168 bis 171
Aufgabe
Welche Aufgabe zu lösen ist:
Der Weihnachtsmann verpackt seine Geschenke in Schachteln, die er in seinem Schachtellager gelagert hat.
Geschenke und Schachteln haben unterschiedliche Formen.
Die Grundfläche einer Schachtel kann entweder ein Kreis, ein Quadrat oder ein Rechteck sein.
Auch Geschenke haben eine Grundfläche, die entweder in einen Kreis, in ein Quadrat oder in ein nichtquadratisches Rechteck hineinpasst.
Geschenke sollen so in einer Schachtel verpackt werden, dass sie nicht verrutschen können.
So passt z.B. eine Weinflasche in eine Schachtel mit einem kreisförmigen, aber auch mit einem quadratischen Boden.
Ein Rubikwürfel passt in eine Schachtel mit quadratischem Boden, aber nicht in eine mit rechteckigem Boden, da der Würfel darin verrutschen würde.
Ein Buch passt nur in eine Schachtel mit rechteckigem Boden.
Rechteckige oder quadratische Geschenke sollen aber nicht in kreisförmigen Schachteln verpackt werden, da zu viel Raum verloren gehen würde.
Um die Spannung beim Auspacken zu erhöhen ist es sehr beliebt, ein Geschenk in mehreren Schachteln zu verpacken, z.B. etwas Wertvolles in eine kleine Schachtel, diese Schachtel in eine mittlere und diese in eine große Schachtel, d.h. auch eine Schachtel kann als Geschenk gesehen werden.
Geschenke haben einen Namen, eine Höhe (in cm) und abhängig von der Art des Geschenks Informationen über die Grundfläche (in cm) gespeichert (Kreis: Durchmesser; Quadrat: Seitenlänge; Rechteck: Länge und Breite).
Von einer Schachtel werden die Innenmaße (in cm, Höhe und abhängig von der Art Informationen über die Grundfläche) gespeichert.
Die Kartondicke beträgt 5mm, d.h. die Aussenmaße einer Schachtel sind um 1cm größer als die Innenmaße.
Weiters wird zu jeder Schachtel gespeichert, welches Geschenk sich in der Schachtel befindet.
Entwickeln Sie ein Javaprogramm, das ein Schachtellager mit leeren Schachteln und einen Geschenkesack des Weihnachtsmanns, der Schachteln mit Geschenken enthält, verwalten kann.
Entwickeln Sie Klassen(hierarchien) um Geschenke, Schachteln, das Lager und den Geschenkesack darzustellen.
Geschenke und Schachteln, ein Lager und ein Geschenkesack sollen erzeugt werden.
Das Lager und der Geschenkesack sollen befüllt werden.
Weiters sollen folgende Methoden und Funktionalitäten unterstütz werden:
- Eine Methode verpacke für ein Geschenk, die eine passende Schachtel aus dem Lager (Geschenk darf nicht verrutschen können) für das Geschenk liefert und das Geschenk in die Schachtel gibt.
Gibt es keine passende Schachtel im Lager (für Geschenke mit runder Grundflächer weder eine Schachtel mit runder noch mit quadratischer Grundfläche), soll eine neue Schachtel passender Form und Größe erstellt werden.
- Eine Methode volumen für eine Schachtel, die das Volumen einer Schachtel zurückliefert (Außenmaße).
Das Volumen berechnet sich aus Grundfläche*Höhe.
- Eine Methode volumen für den Sack, die die Summe der Volumen aller im Sack befindlichen Schachteln zurückliefert.
- Eine Methode geschenke für den Sack, die für alle Schachteln im Sack den Namen der darin enthaltenen Geschenke auf die Standardausgabe ausgibt.
Entwickeln Sie eigene Klassen für Geschenke (Bücher, Bälle, ...), mindestens zwei von unterschiedlicher Größe für jede Art von Grundflächen.
Sorgen Sie dafür, dass zwischen allen Klassen für Geschenke und Schachteln, die zueinander in einer Untertypbeziehung stehen können, auch tatsächlich Untertyp- und Vererbungsbeziehungen bestehen.
Schreiben Sie eine Klasse Test, die das Lager, den Geschenkesack, alle Klassen von Geschenken und Schachteln und alle Untertypbeziehungen testet.
Warum die Aufgabe diese Form hat:
Neben einer Einstimmung auf Weihnachten beinhaltet diese Aufgabe mehrere Details, die den Einsatz bestimmter Entwurfsmuster nahelegen.
Durch viele Arten von Geschenken und Schachteln ergibt sich eine einheitliche, aber umfangreiche Struktur an Untertypbeziehungen, die auch parallele Teilstrukturen enthält.
Was im Hinblick auf die Beurteilung zu beachten ist:
Der Schwerpunkt bei der Beurteilung liegt auf korrekten Untertypbeziehungen und der sinnvollen Verwendung von Entwurfsmustern.
Kräftige Punkteabzüge gibt es für
- Verletzungen des Ersetzbarkeitsprinzips bei Verwendung von Vererbungsbeziehungen sowie fehlende Vererbungsbeziehungen, wo eine Untertypbeziehung bestehen könnte,
- vermeidbare mehrfache Vorkommen gleicher oder ähnlicher Code-Stücke (wie z.B. verpacke oder volumen).
Punkteabzüge gibt es auch für unnötigen (oder unnötig komplexen) Code, mangelhafte Zusicherungen und falsche Sichtbarkeit.
Wie die Aufgabe zu lösen ist:
Obwohl ein Schwerpunkt auf dem gezielten Einsatz von Entwurfsmustern liegt, werden in dieser Aufgabe wesentliche Teile des gesamten bisher durchgenommenen Vorlesungsstoffs geübt.
Es ist vor allem wichtig, alle Untertypbeziehungen zu finden und die Ersetzbarkeit auf geeignete Weise (auch durch Testfälle) sicherzustellen.
Überlegen Sie sich, wo Sie (abstrakte) Klassen und Interfaces verwenden.
Beachten Sie die Sichtbarkeit.
Wenn sinnvoll, sollen Generizität bzw. (vorgefertigte) Containerklassen benützt werden.