• Keine Ergebnisse gefunden

Übungen zur Vorlesung Software Engineering – WS 16/17

N/A
N/A
Protected

Academic year: 2022

Aktie "Übungen zur Vorlesung Software Engineering – WS 16/17"

Copied!
2
0
0

Wird geladen.... (Jetzt Volltext ansehen)

Volltext

(1)

Intelligente Softwaresysteme

Prof. Dr.-Ing. Norbert Siegmund | Philipp Seltmann Abgabetermin:17.11.2016 um 23:59 Uhr

Übungen zur Vorlesung

Software Engineering – WS 16/17

Übungsblatt 04

1. Adapter Pattern: Deque(8 Punkte)

Implementieren Sie die DatenstrukturDequein Java mit Hilfe des Adapter Patterns. Die Ope- rationen der Deque sind:

• PUSHundPOP: Einfügen und Entnehmen eines Elementes am hinteren Ende der Deque

• PUTundGET: Einfügen und Entnehmen am vorderen Ende der Deque

• FIRSTundLAST: Lesen des ersten oder letzten Elements, ohne es zu entfernen.

Achten Sie bei Ihrer Implementierung auf Java Generics und bauen Sie Ihre Lösung auf eine bestehende "Collection", wie z.B.java.util.ArrayList, auf! Vergewissern Sie sich, dass Ihre neue Klassekeineweiteren Methoden als die oben genannten ausführen kann (z.B.add() oderclear()).

2. Visitor Pattern: Termausgabe(6 + 7 Punkte)

Wir betrachten Terme über die Rechenartenop∈ {+,·}, die folgendermaßen rekursiv definiert sind:

• jedes Literal ist ein Term, z.B. "4"

• isttein Term, so ist(t)ein Term

• sindt1,t2Terme so istt1op t2ebenso ein Term

Beispiele für gültige Terme: "4+8", "4·8" oder "4+ (4·8)".

a) Implementieren Sie die entsprechenden KlassenExpression, Literal, Brackets, BinaryExpression, Addition und Multiplication im Sinne des Visitor Pat- terns.

b) Implementieren Sie danach die Visitor KlassenEvalVisitorundPrettyPrintVisitor. EvalVisitor: Evaluiert bzw. berechnet den gegebenen Term und hält das Ergebnis

PrettyPrintVisitor: Gibt einen Term in leserlicher Form aus.

Prüfen Sie Ihre Implementierung durch geeignete Tests!

(2)

Hinweise zur Abgabe

• Erstellen sie zur Abgabe Ihrer Lösungeine PDF-Datei, in der Texte und Grafiken zu den Auf- gaben enthalten sind.

• Sämtlicher Quellcode ist als Plain-Text mit entsprechender Dateiendung zu übersenden. Quell- code in dem PDF-Dokument wirdnichtkorrigiert werden!

• Für eine eindeutige Zuordnung referenzieren Sie Ihre Quellcode-Dateien in dem PDF-Dokument.

• Versehen Sie Ihr PDF-Dokument bitte mitNameund Matrikelnummerder jeweiligen Team- mitglieder.

• Zippen Sie Ihre Lösungen unter dem folgenden Namensschema (bei Teamabgaben reicht eine Person):<Nachname>-<MatrikelNr>-se-blatt<Übungsnummer>.zip

• Senden Sie Ihre Abgabe an Philipp Seltmann (philipp.seltmann@uni-weimar.de)

Referenzen

ÄHNLICHE DOKUMENTE

Es sollen zwei verschiedene Arten von Bildern repräsentiert werden können: RasterImage und ShapedImage, wobei letzteres eine Spezial- form vom RasterImage ist.. Ein ShapedImage

Ein ShapedImage besitzt eine nicht-rechteckige Form (Polygon), wobei die Bytes im Array angeben, ob die jeweiligen Punkte transparent oder opak darge- stellt werden sollen..

e) Birgt es Gefahren, wenn eine Test-Suite ausschließlich Unit-Tests enthält. Wenn ja,

So you learned that casual users and novices want to use the software mainly for short tasks such as image cropping, changing image resolutions, and rota- ting images.. In addition,

a) Erstellen Sie ein Diagramm, welches die Beziehungen der einzelnen Komponenten des Model-View-Controller Architektur-Patterns zueinander visualisiert... b) Welche Aufgaben werden

Insgesamt sind explizit vier Bugs zu finden und wenn möglich eine potentiell gefährliche Stel- le (Zusatz). Ihre Abgabe soll sowohl das Protokoll als auch den korrigierten

Suchen Sie sich eine existierende mobile Applikation, mit der Sie vertraut sind, aus.. Stellen Sie sich vor, dass Sie die Aufgabe bekommen haben, eine äquivalente Applikation

Falls über den üblichen Rahmen hinausgehende Qualitätsanforderungen erfüllt werden sollen (z.B. für Buchungssysteme, Kernkraftanlagen), sollten diese hier niedergelegt