MUSTERLÖSUNG Softwaretechnik
|
|
|
- Werner Sachs
- vor 6 Jahren
- Abrufe
Transkript
1 MUSTERLÖSUNG Softwaretechnik Prof. Dr. Walter F. Tichy Dipl.-Inform. T. Gelhausen Dipl.-Inform. A. Paar Hier das Namensschild aufkleben. Zur Klausur sind keine Hilfsmittel und kein eigenes Papier zugelassen. Die Bearbeitungszeit beträgt 60 Minuten. Die Klausur ist vollständig und geheftet abzugeben. Mit Bleistift oder roter Farbe geschriebene Angaben werden nicht bewertet. Aufgabe Maimal K1 K2 K3
2 Aufgabe 1: Aufwärmen (18P) a.) Nennen Sie fünf in der Vorlesung genannte Kapitel eines Lastenheftes. (2,5P) Zielbestimmung Produkteinsatz Produktfunktionen 5 0,5 = 2,5P Produktdaten Produktleistungen, Qualitätsanforderungen, Ergänzungen, Glossar b.) Nennen Sie drei Anforderungs-Erhebungstechniken. Geben Sie für jede Technik jeweils einen Vor- und einen Nachteil an. (3P) z.b. Introspektion, Vorteil: einfach, schnell, billig Nachteil: oft nicht anwendbar = 3P z.b. Umfragen, Fragebögen, Vorteil: kann über das Web durchgeführt werden, Nachteil: wenig Kontet z.b. Ethnografie, Vorteil: zuverlässig, reichhaltiger Kontet, Nachteil: etrem zeitaufwendig c.) In der Vorlesung wurden für den Vergleich zweier Objekte mehrere Stufen von Gleichheit definiert. Geben Sie die Definitionen für Gleichheit 0. und 1. Stufe an. (3P) Gleichheit 0. Stufe: Es handelt sich um dasselbe Objekt, die Objekte sind identisch. (1P) Gleichheit 1. Stufe: Es handelt sich entweder um dasselbe Objekt oder zwei verschiedene Objekte, die aber in allen Attributen/Assoziationen identische Werte besitzen (Gleichheit 0. Stufe oder paarweise Gleichheit 0. Stufe in allen Attributen). (2P) Klausur Softwaretechnik Wintersemester 2007/2008 Seite 2 von 11
3 d.) Gegeben sind die folgenden Definitionen der Java-Klassen A und B. class A { public void print() { System.out.println("A"); class B etends A { public void print() { System.out.println("B"); Kreuzen Sie die Ausgabe der folgenden Java-Anweisungen an. (1P) A a = new B(); a.print(); A B AmbiguousCallEception e.) Erläutern Sie: Was ist Kontravarianz bei Eingabeparametern? Was ist Kovarianz bei Ausgabeparametern? (2P) Kontravariante Eingabeparameter: Mit zunehmender Spezialisierung der Klasse in der eine Methode überschrieben wird nimmt die Spezialisierung des Eingabeparameters ab. (1P) Kovariante Ausgabeparameter: Mit zunehmender Spezialisierung der Klasse in der eine Methode überschrieben wird nimmt die Spezialisierung des Ausgabeparameters zu. (1P) f.) Wie wurde die Benutzt -Relation in der Vorlesung definiert? (1P) Programmkomponente A benutzt Programmkomponente B genau dann, wenn A für den korrekten Ablauf die Verfügbarkeit einer korrekten Implementierung von B erfordert. (1P) Klausur Softwaretechnik Wintersemester 2007/2008 Seite 3 von 11
4 Wahr Falsch g.) Kreuzen Sie an, ob die folgenden Aussagen wahr oder falsch sind. (5,5P) Hinweis: Jedes korrekte Kreuz zählt 0,5 Punkte, jedes falsche Kreuz bewirkt 0,5 Punkte Abzug. Die Teilaufgabe wird mindestens mit 0 Punkten bewertet. Aussage Ein Pflichtenheft spezifiziert die Anforderungen an eine Software in eindeutiger Weise, so dass sie implementiert werden können. Ein Modul sollte ohne Kenntnis der späteren Nutzung entworfen, implementiert, getestet und überarbeitet werden können. Kontravariante Eingabe-Parameter erfüllen das Substitutionsprinzip. In Java ist das Entwurfsmuster Null-Objekt durch das Schüsselwort null realisiert. Das Test-Rahmenwerk JUnit erzeugt für ein gegebenes Programm automatisch Testfälle für kontrollflußorientierte Testverfahren. Ein Laufzeitübersetzer (JIT) kann bestimmen, ob die ausgerollte oder die nicht ausgerollte Variante einer Schleife für die aktuelle Laufzeitumgebung besser geeignet ist. Um ein Programm zu testen, können Regressionstests und Zusicherungen kombiniert werden. Das Entwurfsmuster Strategie bietet die Möglichkeit, eine Klasse mit einer von mehreren möglichen Verhaltensweisen zu konfigurieren. Eine Fabrikmethode kann eine Einschubmethode bei einer Schablonenmethode für Objekterzeugung sein. In einem UML-Anwendungsfalldiagramm werden typische Interaktionen des Benutzers mit dem System modelliert. In UML-Aktivitätsdiagrammen wird nicht zwischen Objekt- und Kontrollflüssen unterschieden. Klausur Softwaretechnik Wintersemester 2007/2008 Seite 4 von 11
5 Aufgabe 2: Entwurfsmuster (13P) Sie möchten einen Zerteiler (Parser) für arithmetische Ausdrücke programmieren. Die folgenden Java-Klassen repräsentieren die einzelnen Bestandteile solcher arithmetischer Ausdrücke. Konkrete arithmetische Ausdrücke können somit als Baum von Instanzen dieser Klassen im Speicher dargestellt werden. rechteseite <<Interface>> IAusdruck linkeseite + prettyprint() BinaererAusdruck + stroperator : String + prettyprint() Variable + strname : String + prettyprint() a.) Betrachten Sie den arithmetischen Ausdruck = a + b. Geben Sie für diesen konkreten arithmetischen Ausdruck ein entsprechendes UML-Objektdiagramm an. Verwenden Sie die gegebenen Klassendefinitionen. Hinweis: Sie brauchen die Objekte nicht zu benennen, sondern können anonyme Objekte verwenden. (3,5P) linkeseite :Variable strname = :BinaererAusdruck stroperator = = linkeseite :Variable strname = a rechteseite :BinaererAusdruck stroperator = + rechteseite :Variable strname = b Klausur Softwaretechnik Wintersemester 2007/2008 Seite 5 von 11
6 b.) Die Klassen BinaererAusdruck und Variable weisen beide die gemeinsame Funktion prettyprint() auf. Während sich die Struktur des Klassenmodells in Zukunft nicht verändern wird, sind für die weitere Entwicklung eine Reihe von neuen Operationen für die Klassen BinaererAusdruck und Variable geplant. Sie entscheiden sich daher, vorausschauend das Entwurfsmuster Besucher zu verwenden und die Operation prettyprint() in einer Besucherklasse zu kapseln. Zeichnen Sie ein UML-Klassendiagramm, das für das gegebene Klassenmodell eine abstrakte Besucherklasse und einen konkreten PrettyPrintBesucher enthält. Deklarieren Sie alle Methoden als public. (3,5P) Besucher {abstract + besuchebinaerenausdruck(b : BinaererAusdruck) + besuchevariable (v :Variable) PrettyPrintBesucher + besuchebinaerenausdruck (b : BinaererAusdruck) + besuchevariable (v :Variable) c.) Vervollständigen Sie das folgende Klassendiagramm um Funktionen, die für das Verwenden des in Aufgabenteil b.) entworfenen Besuchers notwendig sind. Deklarieren Sie alle Methoden als public. (1,5P) rechteseite <<Interface>> IAusdruck linkeseite + empfangebesucher(b : Besucher) BinaererAusdruck + stroperator : String + empfangebesucher(b : Besucher) Variable + strname : String + empfangebesucher(b : Besucher) Klausur Softwaretechnik Wintersemester 2007/2008 Seite 6 von 11
7 d.) Die folgende Schnittstelle IAusdrucksVisualisierer wird von Ihrem Programm als visuelle Komponente verwendet, um arithmetische Ausdrücke auf dem Bildschirm auszugeben. Der Methode zeichne(s : String) übergibt man dazu den arithmetischen Ausdruck als Zeichenkette, die von dem konkreten AusdrucksVisualisierer dargestellt wird. Verwenden Sie das Entwurfsmuster Dekorierer um einen RahmenDekorierer zu entwerfen. Dieser soll eine zusätzliche Methode zeichnerahmen() bieten, die die visuelle Komponente mit einem Rahmen dekoriert. Ergänzen Sie dazu das folgende UML- Klassendiagramm um einen abstrakten Dekorierer und um einen konkreten Rahmendekorierer. Geben Sie die Implementierung der zeichne(s : String) Methode in dem konkreten Dekorierer an (Die Implementierung der Methode zeichnerahmen() brauchen Sie nicht anzugeben). (4,5P) <<Interface>> IAusdrucksVisualisierer komponente + zeichne(s : String) 1,5P AusdrucksVisualisierer Dekorierer {abstract + zeichne(s : String) + zeichne(s : String) komponente.zeichne(s) 2P RahmenDekorierer 1P + zeichnerahmen() + zeichne(s : String) super.zeichne(s) zeichnerahmen() oder komponente.zeichne(s) zeichnerahmen() Klausur Softwaretechnik Wintersemester 2007/2008 Seite 7 von 11
8 Aufgabe 3: Objektorientierte Analyse & Entwurf (17P) Gegeben sei folgender Auszug aus der Anwendungsdomänenbeschreibung von HOAX, einem Rechtemanagement-System für Videodateien: [ ]Alle Inhalte sind entweder mit dem Verfahren AES-128 oder Triple-DES verschlüsselt. Der zu einem Inhalt gehörende Schlüssel wird vom Abspielgerät aus dem im Gerät gespeicherten und gesicherten DeviceKey und dem auf dem Medium gespeicherten MediaKey berechnet. Bei vorbespielten Medien haben alle Kopien eines Titels den gleichen MediaKey. Bei Leermedien hat jedes Medium einen eigenen, individuellen MediaKey; es gibt also keine zwei Leermedien mit dem gleichen MediaKey. Ein Aufzeichnungsgerät muss daher für jedes Leermedium einen eigenen, vom MediaKey des Mediums und vom DeviceKey abhängigen Schlüssel für den Inhalt erzeugen. [ ] a.) Nehmen wir an, HOAX soll in einer zukünftigen Version mit weiteren Verschlüsslungsalgorithmen arbeiten können. Welches Entwurfsmuster sollte dann verwendet werden? Begründen Sie Ihre Aussage. Geben Sie an, wer welche Rolle des Musters annimmt. (2P) Hinweis 1: Das Entwurfsmuster Oberklasse ist nicht gemeint. Hinweis 2: Sie sollen das Entwurfsmuster in Aufgabenteil b.) auch einsetzen. Entwurfsmuster: Strategie. (0,5P) AES, Triple-DES und weitere sind alle Verschlüsselungsalgorithmen und bilden eine Familie (0,5P). Der Klient (=Abspielgerät, 0,5P) möchte sie einheitlich verwenden und einfach austauschen (Kapselung, Zweck: Austausch/Variation, 0,5P) können. b.) Modellieren Sie den beschriebenen Teil von HOAX möglichst genau in einem einzigen UML-Klassendiagramm. Sachverhalte, die man nicht mit dem Klassendiagramm ausdrücken kann, geben Sie bitte in OCL an. Verwenden Sie Ihr in Aufgabenteil a.) identifiziertes Entwurfsmuster und markieren Sie es deutlich. (15P) Hinweise: Modellieren Sie nichts, das nicht im Tet erwähnt wird oder für die Implementierung des Entwurfsmusters notwendig ist. Vergessen Sie insbesondere nicht die Methoden, die für das Entwurfsmuster notwendig sind. Modellieren Sie keine Sichtbarkeiten. Geben Sie aber überall Multiplizitäten und Assoziationsnamen an. Geben Sie Rollen wo nötig an. OCL-Tipp: Die Kollektion X.allInstances enthält alle Instanzen der Klasse X. Klausur Softwaretechnik Wintersemester 2007/2008 Seite 8 von 11
9 contet VorbespieltesMedium inv: VorbespieltesMedium.allInstances->forAll( other (self.titel = other.titel) implies self.meinschlüssel.istgleich( other.meinschlüssel ) contet Leermedium inv: Leermedium.allInstances->forAll( other self.meinschlüssel.istgleich( other.meinschlüssel ) implies (self = other) Klausur Softwaretechnik Wintersemester 2007/2008 Seite 9 von 11
10 Aufgabe 4: Testen (12P) public static enum Color { Cyan, Magenta, Yellow, Black ; public int applygamma( int value, Color c, int[] gammatable ) { switch( c ) { case Cyan: value *= 1.2; break; case Magenta: value *= value; // no break!!! case Yellow: value *= 1.7; break; case Black: value = (int)math.sqrt( value ); break; value = gammatable[value]; return value; a.) Beschreiben Sie ein Verfahren, wie man die in der Vorlesung nicht behandelte switch- Anweisung aus Java in die strukturerhaltende Zwischensprache aus der Vorlesung überführen kann. Geben Sie zur Veranschaulichung das entstehende Zwischensprachprogramm an. (insges. 9P) Hinweis: Den default-fall brauchen Sie nicht zu beachten. Beschreibung der Umsetzungsvorschrift (5P): Man verwandelt die switch-anweisung in eine Kaskade von bedingten Sprüngen in einen Codeblock, der alle inneren Instruktionen der switch-anweisung in der selben Reihenfolge enthält (1P). Jeder Fall wird zu einem bedingten Sprung (1P). Jedes label (case XY: ) wird zu einem Sprungziel (1P). Jedes break zu einem unbedingten Sprung an das Ende des ganzen Blocks (1P). Bei einem fehlenden break (1P) ist nichts zu tun ( fall-through ). Klausur Softwaretechnik Wintersemester 2007/2008 Seite 10 von 11
11 Zwischensprachprogramm (4P): public int applygamma( int value, Color c, int[] gammatable ) { 10: if (c==cyan) goto 60; 20: if (c==magenta) goto 80; 30: if (c==yellow) goto 90; 40: if (c==black) goto 110; 50: goto 130; // falls kein Fall zutrifft 60: value *= 1.2; 70: goto 130; 80: value *= value; 90: value *= 1.7; 100: goto 130; 110: value = (int)math.sqrt( value ); 120: goto 130; 130: value = gammatable[value]; (1P pro korrekt umgesetztem Fall) b.) return value; Übertragen Sie Ihre Erkenntnisse aus Teilaufgabe a.) auf den allgemeinen Fall: Was ist Voraussetzung, wenn man Zweigüberdeckung für eine beliebige switch-anweisung erreichen will? Und unter welchen speziellen Voraussetzungen erfüllen Testdaten, die für eine switch-anweisung Anweisungsüberdeckung erreichen, gleichzeitig auch die Kriterien der Zweigüberdeckung? (3P) Hinweis: Den default-fall brauchen Sie nicht zu beachten. Um bei einem switch-ausdruck Zweigüberdeckung zu erreichen, muss jeder Fall ein Mal angesprungen werden (1P). Testdaten für die Anweisungsüberdeckung erfüllen auch dann die Voraussetzungen für die Zweigüberdeckung, wenn kein break fehlt (kein fall-through ) (1P) und keine weiteren Verzweigungen in den Code-Blöcken vorkommen (1P). (Hinweis: Fehlende breaks führen dazu, dass Anweisungsüberdeckung leichter zu erfüllen ist, Zweigüberdeckung dann aber gerade nicht mehr erfüllt wird!) Klausur Softwaretechnik Wintersemester 2007/2008 Seite 11 von 11
Klausur Softwaretechnik
Klausur Softwaretechnik 14.03.2008 Prof. Dr. Walter F. Tichy Dipl.-Inform. T. Gelhausen Dipl.-Inform. A. Paar Hier das Namensschild aufkleben. Zur Klausur sind keine Hilfsmittel und kein eigenes Papier
KLAUSUR SOFTWARETECHNIK
KLAUSUR SOFTWARETECHNIK 17.09.2009 Prof. Dr. Walter F. Tichy Dipl.-Inform. Andreas Höfer Dipl.-Inform. David J. Meder Hier das Namensschild aufkleben. Zur Klausur sind keine Hilfsmittel und kein eigenes
Klausur Softwaretechnik
Klausur Softwaretechnik 15.03.2007 Prof. Dr. Walter F. Tichy Dipl.-Inform. T. Gelhausen Dipl.-Inform. G. Malpohl Hier das Namensschild aufkleben. Zur Klausur sind keine Hilfsmittel und kein eigenes Papier
Klausur Softwaretechnik I
Klausur Softwaretechnik I 06.08.2009 Prof. Dr. Walter F. Tichy Dipl.-Inform. A. Höfer Dipl.-Inform. D. Meder Hier das Namensschild aufkleben. Zur Klausur sind keine Hilfsmittel und kein eigenes Papier
Klausur Softwaretechnik
Klausur Softwaretechnik 04.09.2008 Prof. Dr. Walter F. Tichy Dipl.-Inform. T. Gelhausen Dipl.-Inform. A. Paar Hier das Namensschild aufkleben. Zur Klausur sind keine Hilfsmittel und kein eigenes Papier
Klausur Softwaretechnik
Klausur Softwaretechnik 16.03.2006 Prof. Dr. Walter F. Tichy M. Sc. A. Jannesari Dipl.-Inform. G. Malpohl Hier das Namensschild aufkleben. Zur Klausur sind keine Hilfsmittel und kein eigenes Papier zugelassen.
KLAUSUR SOFTWARETECHNIK I
KLAUSUR SOFTWARETECHNIK I 12.10.2009 Prof. Dr. Walter F. Tichy Dipl.-Inform. Andreas Höfer Dipl.-Inform. David J. Meder Hier das Namensschild aufkleben. Zur Klausur sind keine Hilfsmittel und kein eigenes
KLAUSUR SOFTWARETECHNIK
KLAUSUR SOFTWARETECHNIK 17.09.2009 Prof. Dr. Walter F. Tichy Dipl.-Inform. Andreas Höfer Dipl.-Inform. David J. Meder Musterlösung Zur Klausur sind keine Hilfsmittel und kein eigenes Papier zugelassen.
Universität zu Lübeck Institut für Telematik. Prof. Dr. Stefan Fischer
Universität zu Lübeck Institut für Telematik Prof. Dr. Stefan Fischer Probeklausur im Fach Programmieren Hinweise zur Bearbeitung: Es sind keinerlei Hilfsmittel zugelassen. Diese Klausur umfasst 18 Seiten.
Klausur Softwaretechnik I
Klausur Softwaretechnik I 06.08.2009 Prof. Dr. Walter F. Tichy Dipl.-Inform. A. Höfer Dipl.-Inform. D. Meder Musterlösung Zur Klausur sind keine Hilfsmittel und kein eigenes Papier zugelassen. Die Bearbeitungszeit
Klausur Softwaretechnik Prof. Dr. Walter F. Tichy Dipl.-Inform. T. Gelhausen Dipl.-Inform. G. Malpohl. Musterlösung
Klausur Softwaretechnik 15.03.2007 Prof. Dr. Walter F. Tichy Dipl.-Inform. T. Gelhausen Dipl.-Inform. G. Malpohl Musterlösung Punkte Note 0 5,0 18 4,0 21 3,7 24 3,3 27 3,0 30 2,7 33 2,3 36 2,0 39 1,7 42
Klausur. Softwareentwurf. 13. März 2013 Bearbeitungszeit: 120 Minuten
Klausur Softwareentwurf 13. März 2013 Bearbeitungszeit: 120 Minuten FG Datenbank- und Informationssysteme Dr. Christian Gerth unbedingt vollständig und lesbar ausfüllen! Vorname: Matrikelnummer: [ ] Informatik
Probeklausur: Programmierung WS04/05
Probeklausur: Programmierung WS04/05 Name: Hinweise zur Bearbeitung Nimm Dir für diese Klausur ausreichend Zeit, und sorge dafür, dass Du nicht gestört wirst. Die Klausur ist für 90 Minuten angesetzt,
Klausur Grundlagen der Programmierung
Klausur Grundlagen der Programmierung Aufgabenstellung: Martin Schultheiß Erreichte Punktzahl: von 60 Note: Allgemeine Hinweise: Schreiben Sie bitte Ihren Namen auf jedes der Blätter Zugelassene Hilfsmittel
Probeklausur Java Einführung in die Informatik. Wintersemester 2016/2017
Fakultät IV NI & CV Java Einführung in die Informatik Wintersemester 2016/2017 Hinweis: Diese ist eine kleine Aufgabensammlung, die etwa dem Schwierigkeitsgrad der schriftlichen Prüfung des Moduls Einführung
Theorie zu Übung 8 Implementierung in Java
Universität Stuttgart Institut für Automatisierungstechnik und Softwaresysteme Prof. Dr.-Ing. M. Weyrich Theorie zu Übung 8 Implementierung in Java Klasse in Java Die Klasse wird durch das class-konzept
Klausur Softwaretechnologie SS 2017
Fakultät Informatik Institut für Software- und Multimediatechnik, Professur Softwaretechnologie Technische Universität Dresden, 01062 Dresden Klausur Softwaretechnologie SS 2017 Prof. Dr.rer.nat.habil.
Semestrale Softwaretechnik: Software-Engineering
Semestrale Softwaretechnik: Software-Engineering Dr. Bernhard Rumpe WS 2002/2003 06. Februar 2003 Nachname: Vorname: Matrikelnummer: Hauptfach: Informatik als: [ ] Diplom [ ]Bachelor [ ]Master [ ]Nebenfach
Aufgaben Objektentwurf
Aufgaben Objektentwurf (Einschub zum 5. Tutorium) Tutorium 6 13. März 2009 Svetlana Matiouk, Uni Bonn Ferientutorien zur Vorlesung Softwaretechnologie WS 2008 6. Treffen, Aufgabe 1 Vorwärtsmodellierung
Klausur zur Vorlesung Einführung in Verteilte Systeme WS 05/06 Prof. Dr. Odej Kao 3. Februar 2006
Klausur zur Vorlesung Einführung in Verteilte Systeme WS 05/06 Prof. Dr. Odej Kao 3. Februar 2006 Aufkleber Name: Vorname: Matrikel: Studiengang: inkl. DPO4, B/M, Schwerp., Schreiben Sie zunächst Ihren
Einstieg in die Informatik mit Java
Vorlesung vom 18.4.07, Grundlagen Übersicht 1 Kommentare 2 Bezeichner für Klassen, Methoden, Variablen 3 White Space Zeichen 4 Wortsymbole 5 Interpunktionszeichen 6 Operatoren 7 import Anweisungen 8 Form
Bachelorprüfung: Objektorientierte Softwareentwicklung
Bachelorprüfung: Objektorientierte Softwareentwicklung WS10/11 Erlaubte Hilfsmittel: keine Lösung ist auf den Klausurbögen anzufertigen. (eventuell Rückseiten nehmen) Bitte legen Sie einen Lichtbildausweis
Institut für Programmierung und Reaktive Systeme 2. Februar Programmieren I. Übungsklausur
Technische Universität Braunschweig Dr. Werner Struckmann Institut für Programmierung und Reaktive Systeme 2. Februar 2017 Hinweise: Klausurtermine: Programmieren I Übungsklausur Programmieren I: 13. März
Objektorientierte Programmierung. Kapitel 22: Aufzählungstypen (Enumeration Types)
Stefan Brass: OOP (Java), 22. Aufzählungstypen 1/20 Objektorientierte Programmierung Kapitel 22: Aufzählungstypen (Enumeration Types) Stefan Brass Martin-Luther-Universität Halle-Wittenberg Wintersemester
FH D. Objektorientierte Programmierung in Java FH D FH D. Prof. Dr. Ing. André Stuhlsatz. Blöcke. Beispiel: Variablen in Blöcken
4 Objektorientierte Programmierung in Java Prof. Dr. Ing. André Stuhlsatz Blöcke Blöcke erweitern einzelne Anweisungen, etwa bei Kontrollstrukturen später Beispiel: Einzelne Anweisung: anweisung; Erweiterung
2 Teil 2: Nassi-Schneiderman
2 Teil 2: Nassi-Schneiderman Wie kann man Nassi-Schneiderman in einer objektorientierten Sprache verwenden? Jedes Objekt besitzt Methoden, welche die Attribute des Objektes verändern. Das Verhalten der
Klausur. Softwareentwurf. 14. Februar 2011 Bearbeitungszeit: 120 Minuten
Klausur Softwareentwurf 14. Februar 2011 Bearbeitungszeit: 120 Minuten FG Datenbank- und Informationssysteme Prof. Dr. Gregor Engels unbedingt vollständig und lesbar ausfüllen! Vorname: Matrikelnummer:
Sichtbarkeiten, Klassenmember und -methoden
Sichtbarkeiten, Klassenmember und -methoden Prof. Dr.-Ing. Thomas Schwotzer 11. November 2017 1 Einführung Wir haben uns mit Klassen und Objekten beschäftigt. Wir wissen nun, dass Objekte anhand von Klassen
Institut für Programmierung und Reaktive Systeme 25. Januar Programmieren I. Übungsklausur
Technische Universität Braunschweig Dr. Werner Struckmann Institut für Programmierung und Reaktive Systeme 25. Januar 2018 Hinweise: Klausurtermine: Programmieren I Übungsklausur Programmieren I: 17. Februar
Abgabe: keine Pflichtabgabe (vor 12 Uhr) Aufgabe 10.1 (P) Vererbung Gegeben seien folgende Java-Klassen:
TECHNISCHE UNIVERSITÄT MÜNCHEN FAKULTÄT FÜR INFORMATIK Lehrstuhl für Sprachen und Beschreibungsstrukturen SS 2011 Einführung in die Informatik I Übungsblatt 10 Prof. Dr. Helmut Seidl, A. Lehmann, A. Herz,
Klausur Software-Entwicklung März 01
Aufgabe 1: minimaler Punktabstand ( 2+5 Punkte ) Matrikelnr : In einem Array punkte sind Koordinaten von Punkten gespeichert. Ergänzen Sie in der Klasse Punkt eine Klassen-Methode (=static Funktion) punktabstand,
UNIVERSITÄT SIEGEN Fachbereich 12, Elektrotechnik und Informatik Fachgruppe Betriebssysteme / verteilte Systeme
UNIVERSITÄT SIEGEN Fachbereich 12, Elektrotechnik und Informatik Fachgruppe Betriebssysteme / verteilte Systeme Musterklausur zur Einführung in die Informatik II 1. Teilklausur, 23.06.2006 Bitte lesen
Klausur. Softwareentwurf. 22. März 2011 Bearbeitungszeit: 120 Minuten
Klausur Softwareentwurf 22. März 2011 Bearbeitungszeit: 120 Minuten FG Datenbank- und Informationssysteme Prof. Dr. Gregor Engels unbedingt vollständig und lesbar ausfüllen! Vorname: Matrikelnummer: [
Creational Patterns. Seminar Software-Entwurf. Thomas Liro WS 2004/05.
Creational Patterns Seminar Software-Entwurf WS 2004/05 Thomas Liro Inhaltsüberblick Einordnung des Themas Beschreibung von Design Pattern Auswahl von Design Patterns Was sind Creational
Technische Universität Braunschweig Institut für Programmierung und Reaktive Systeme
Technische Universität Braunschweig Institut für Programmierung und Reaktive Systeme Programmieren I Dr. Werner Struckmann 8. September 2014 Name: Vorname: Matrikelnummer: Kennnummer: Anrede: Frau Herr
Objektorientierung. Marc Satkowski 20. November C# Kurs
Objektorientierung Marc Satkowski 20. November 2016 C# Kurs Gliederung 1. Weiterführende Verzweigungen Tertiäre-Verzweigung switch case 2. Schleifen Zählschleife (for) break & continue 3. Objektorientierung
Probeklausur Java Einführung in die Informatik. Wintersemester 2017/2018
Fakultät IV NI & CV Java Einführung in die Informatik Wintersemester 2017/2018 Hinweis: Diese ist eine kleine Aufgabensammlung, die etwa dem Schwierigkeitsgrad der schriftlichen Prüfung des Moduls Einführung
Zweck: sequentieller Zugriff auf Elemente eines Aggregats
Iterator (Cursor) Zweck: sequentieller Zugriff auf Elemente eines Aggregats Anwendungsgebiete: Zugriff auf Aggregatinhalt innere Darstellung bleibt gekapselt mehrere Abarbeitungen des Aggregatinhalts einheitliche
Programmieren in Java
Programmieren in Java Vorlesung 10: Ein Interpreter für While Prof. Dr. Peter Thiemann Albert-Ludwigs-Universität Freiburg, Germany SS 2015 Peter Thiemann (Univ. Freiburg) Programmieren in Java JAVA 1
Java: Eine kurze Einführung an Beispielen
Java: Eine kurze Einführung an Beispielen Quellcode, javac und die JVM Der Quellcode eines einfachen Java-Programms besteht aus einer Datei mit dem Suffix.java. In einer solchen Datei wird eine Klasse
Klausur Softwaretechnologie WS 2014/15
Fakultät Informatik Institut für Software- und Multimediatechnik, Professur Softwaretechnologie Technische Universität Dresden, 01062 Dresden Klausur Softwaretechnologie WS 2014/15 Prof. Dr.rer.nat.habil.
Objektorientierte Programmierung Studiengang Medieninformatik
Objektorientierte Programmierung Studiengang Medieninformatik Hans-Werner Lang Hochschule Flensburg Vorlesung 2 22.03.2017 Was bisher geschah... Klassen und Objekte Attribute und Methoden Klasse Bruch
Einführung in die Programmierung
Skript zur Vorlesung: Einführung in die Programmierung WiSe 2009 / 2010 Skript 2009 Christian Böhm, Peer Kröger, Arthur Zimek Prof. Dr. Christian Böhm Annahita Oswald Bianca Wackersreuther Ludwig-Maximilians-Universität
Entwurfsmuster (Design Patterns)
Entwurfsmuster (Design Patterns) SEP 303 Entwurfsmuster (Design Patterns) In der alltäglichen Programmierarbeit tauchen viele Probleme auf, die man schon einmal gelöst hat und die man in der Zukunft wieder
Probeklausur 2. Name: Vorname: Matrikelnr.: Datum:
Probeklausur 2 Dozent: Prof. Dr. Edmund Ihler Leistungsnachweis: Informatik 4 EDV-Nr.: 13037 Prüfungsdauer: 90 Minuten erlaubte Hilfsmittel: keine Beilagen: keine Name: Vorname: Matrikelnr.: Prüfungsraum:
Beispiele für Ausdrücke. Der imperative Kern. Der imperative Kern. Imperativer Kern - Kontrollstrukturen. Deklarationen mit Initialisierung
Beispiele für Ausdrücke Der imperative Kern Deklarationen mit Initialisierung Variablendeklarationen int i = 10; int j = 15; Beispiele für Ausdrücke i+j i++ i & j i j [] [static]
Unified Modelling Language
Unified Modelling Language SEP 72 Software-Entwicklung Software-Entwicklung ist Prozess von Anforderung über Modellierungen zu fertigen Programmen Anforderungen oft informell gegeben fertige Programme
PRÜFUNG. Grundlagen der Softwaretechnik
Universität Stuttgart Institut für Automatisierungs- und Softwaretechnik Prof. Dr.-Ing. Dr. h. c. P. Göhner PRÜFUNG Grundlagen der Softwaretechnik Name: Matrikelnummer: Note: Prüfungstag: 03.03.2011 Prüfungsdauer:
Javakurs FSS Lehrstuhl Stuckenschmidt. Tag 3 - Objektorientierung
Javakurs FSS 2012 Lehrstuhl Stuckenschmidt Tag 3 - Objektorientierung Warum Objektorientierung Daten und Funktionen möglichst eng koppeln und nach außen kapseln Komplexität der Software besser modellieren
Neben der Verwendung von Klassen ist Vererbung ein wichtiges Merkmal objektorientierter
Kapitel 1 Der vierte Tag 1.1 Vererbung Neben der Verwendung von Klassen ist Vererbung ein wichtiges Merkmal objektorientierter Sprachen. Unter Vererbung versteht man die Möglichkeit, Eigenschaften vorhandener
Geoinformatik und Vermessung Prüfung 502 : Informatik (JAVA)
Geoinformatik und Vermessung Prüfung 502 : Informatik (JAVA) Ihr Name: Matrikelnummer: Allgemeine Hinweise: Erlaubtes Hilfsmittel: Ein beidseitig handbeschriebenes Din-A4-Blatt Tragen Sie Ihren Namen und
Einstieg in die Informatik mit Java
1 / 22 Einstieg in die Informatik mit Java Grundlagen Gerd Bohlender Institut für Angewandte und Numerische Mathematik Gliederung 2 / 22 1 Kommentare 2 Bezeichner für Klassen, Methoden, Variablen 3 White
Konzepte der Programmiersprachen
Konzepte der Programmiersprachen Sommersemester 2010 4. Übungsblatt Besprechung am 9. Juli 2010 http://www.iste.uni-stuttgart.de/ps/lehre/ss2010/v_konzepte/ Aufgabe 4.1: Klassen in C ++ Das folgende C
Gedächtnis. Während der Abarbeitung eines Algorithmus müssen sich Dinge gemerkt werden bzw. auf Dingen wird gerechnet. Zugriff.
Gedächtnis Während der Abarbeitung eines Algorithmus müssen sich Dinge gemerkt werden bzw. auf Dingen wird gerechnet Hauptspeicher 38265 Telefon CPU Gedächtnis Vorlesender Zugriff Verarbeitungseinheit
Klausur - Informatik I SS 05. Note: Bearbeitungszeit 120 Minuten Keine Hilfsmittel
Klausur - Informatik I SS 05 Aufgabe 1 2 3 4 Punkte 40 30 40 10 Gesamtpunkte (max. 120): Note: Bearbeitungszeit 120 Minuten Keine Hilfsmittel Tragen Sie als erstes Ihren vollständigen Namen und Ihre Matrikelnummer
Vererbung. Generalisierung und Spezialisierung Vererbung und Polymorphismus
Vererbung Generalisierung und Spezialisierung Vererbung und Polymorphismus Wir wollen in unserem Aquarium verschiedene Arten von Fischen schwimmen lassen. In einem ersten Ansatz definieren wir nicht nur
Klausur Softwaretechnik
Klausur Softwaretechnik 6.9.2007 Prof. Dr. Walter F. Tichy Dipl.-Inform. T. Gelhausen Dipl.-Inform. G. Malpohl Hier das Namensschild aufkleben. Zur Klausur sind keine Hilfsmittel und kein eigenes Papier
Übungen zur Vorlesung Softwaretechnologie - Wintersemester 2018/19 - Dr. Günter Kniesel. Übungsblatt 10 Lösungen
Übungen zur Vorlesung Softwaretechnologie - Wintersemester 2018/19 - Dr. Günter Kniesel Übungsblatt 10 Lösungen Aufgabe 1. Jahreszeitbedingte Anwendung von Entwurfsmustern (16 Punkte) Ein reichlich geschmückter
UML -Klassendiagramme
UML -Klassendiagramme UML - offline: ArgoUML http://argouml.stage.tigris.org/ UML online: Links genmymodel.com umlet.com/umletino/umletino.html Arten von UML-Diagrammen Diagramm Strukturdiagramm Verhaltensdiagramm
Nachholklausur zur Vorlesung: Einführung in die objektorientierte Programmierung mit Java WS1415
Nachholklausur zur Vorlesung: Einführung in die objektorientierte Programmierung mit Java WS1415 Alexander Bazo 10. April 2015 Allgemeine Hinweise 1. Die Bearbeitungszeit beträgt 60 Minuten. Sie könne
Programmierung WS12/13 Lösung - Präsenzübung M. Brockschmidt, F. Emmes, C. Otto, T. Ströder
Prof. aa Dr. J. Giesl M. Brockschmidt, F. Emmes, C. Otto, T. Ströder Aufgabe 1 (Programmanalyse): (9 + 1 = 10 Punkte) a) Geben Sie die Ausgabe des Programms für den Aufruf java M an. Tragen Sie hierzu
hue12 January 24, 2017
hue12 January 24, 2017 1 Abgabehinweise Beachten Sie unbedingt diese Hinweise, sonst erhalten Sie keine Punkte aus dieser Abgabe! Für Details siehe z.b. Folien der nullten Zentralübung 1.1 Namen und Matrikelnummern
Objektorientierte und Funktionale Programmierung SS 2014
Objektorientierte und Funktionale Programmierung SS 2014 6 Objektorientierte Entwurfsmuster 1 6 Objektorientierte Entwurfsmuster Lernziele Einige wichtige Entwurfsmuster kennen und verstehen Einsatzmöglichkeiten
Programmieren II. Innere Klassen. Heusch 10, Ratz 5.2.1, Institut für Angewandte Informatik
Programmieren II Innere Klassen Heusch 10, 13.10 Ratz 5.2.1, 9.8 KIT Die Forschungsuniversität in der Helmholtz-Gemeinschaft www.kit.edu Innere Klassen Bisher kennen wir nur Klassen, die entweder zusammen
Aufgabe S1: Einmal quer durch s Skript
Aufgabe S1: Einmal quer durch s Skript / 10 Punkten Entscheiden Sie, ob die folgenden Aussagen zutreffen oder nicht. Machen Sie in der entsprechenden Spalte ein Kreuz. Für jede richtige Antwort erhalten
Klausur. Softwareentwurf. 04. Februar 2013 Bearbeitungszeit: 120 Minuten
Klausur Softwareentwurf 04. Februar 2013 Bearbeitungszeit: 120 Minuten FG Datenbank- und Informationssysteme Dr. Christian Gerth unbedingt vollständig und lesbar ausfüllen! Vorname: Matrikelnummer: [ ]
Semestralklausur Informatik I - Programmierung
RHEINISCH- WESTFÄLISCHE TECHNISCHE HOCHSCHULE AACHEN LEHR- UND FORSCHUNGSGEBIET INFORMATIK II RWTH Aachen D-52056 Aachen GERMANY http://www-i2.informatik.rwth-aachen.de/lufgi2 Prof. Dr. Jürgen Giesl LuFG
Anweisungen zur Ablaufsteuerung
Anweisungen zur Ablaufsteuerung if-else switch while do-while for Ausdrücke Ein Ausdruck ist eine Folge von Variablen, Operatoren und Methodenaufrufen, der zu einem einzelnen Wert ausgewertet wird. Operanden
Universität Augsburg, Institut für Informatik Sommersemester 2001 Prof. Dr. Martin Ester 16. Juli Klausur
Universität Augsburg, Institut für Informatik Sommersemester 2001 Prof. Dr. Martin Ester 16. Juli 2001 Stefan Holland Informatik II Hinweise: Klausur Verwenden Sie für Ihre Lösungen ausschließlich den
1. Teilklausur Gruppe A. Bitte in Druckschrift leserlich ausfüllen!
Objektorientierte Programmierung & Modellierung WS 2007/8 Universität Koblenz-Landau Institut für Informatik Prof. Dr. Ralf Lämmel Dr. Manfred Jackel 1. Teilklausur 07.12.2007 Gruppe A Bitte in Druckschrift
Einführung in die objektorientierte Programmierung mit Java. Klausur am 19. Oktober 2005
Einführung in die objektorientierte Programmierung mit Java Klausur am 19. Oktober 2005 Matrikelnummer: Nachname: Vorname: Semesteranzahl: Die Klausur besteht aus drei Frageblöcken zu den Inhalten der
Objektorientierte Systementwicklung
Karl-Heinz Rau Objektorientierte Systementwicklung Vom Geschäftsprozess zum Java-Programm Mit 162 Abbildungen vieweg Überblick und Vorbemerkungen 1 1 Objektorientierte Software-Entwicklung 5 1.1 Überblick
Programmierung für Mathematik HS11
software evolution & architecture lab Programmierung für Mathematik HS11 Übung 8 1 Aufgabe: Codeverständnis (Repetition) 1.1 Lernziele 1. Code verstehen können. 2. Fehler im Code finden und korrigieren
Programmierung für Mathematik (HS13)
software evolution & architecture lab Programmierung für Mathematik (HS13) Übung 11 1 Aufgabe: Codeverständnis 1.1 Aufgabenstellung Notieren Sie, was der folgende Code ausgeben würde, wenn er so in einer
Technische Universität Braunschweig Institut für Programmierung und Reaktive Systeme
Technische Universität Braunschweig Institut für Programmierung und Reaktive Systeme Programmieren I Dr. Werner Struckmann 13. März 2017 Name: Vorname: Matrikelnummer: Kennnummer: Anrede: Frau Herr Studiengang:
4. Übung zu Software Engineering
4. Übung zu Software Engineering WS 2007/2008 Aufgabe 8 Erstellen Sie für den aus Aufgabe 1 bekannten Function-Point-Kalkulator ein Pflichtenheft. Bitte begrenzen Sie dessen Umfang auf maximal 2 DIN A4
Programmieren in Java -Eingangstest-
Programmieren in Java -Eingangstest- Nummer: 1. Studiengang: Informatik B.Sc. Informatik M.Sc. ESE B.Sc. ESE M.Sc. Sonstiges: Fachsemester: Bitte Fragen, die Sie nicht beantworten können unbedingt mit
Gliederung der Folien
1 Gliederung der Folien 1. Einführung 1.1. Gliederung 1.2. Literatur 1.3. Einstieg in Java 1.3.1. Geschichte von Java 1.3.2. Hello World 1.3.3. Übersetzen eines Java-Programms 1.4. Die Entwicklungsumgebung
Softwaretechnik 1 Übung 2
Universität Karlsruhe (TH) Forschungsuniversität gegründet 1825 Softwaretechnik 1 Übung 2 25.5.2009 Aufgabe 1 Klassendiagram // do X firexoccurred(); XListener + xoccurred(e:xevent) * listeners
Welche Informatik-Kenntnisse bringen Sie mit?
Welche Informatik-Kenntnisse bringen Sie mit? So gehen Sie vor! Lösen Sie die Aufgaben der Reihe nach von 1 bis 20, ohne das Lösungsblatt zur Hilfe zu nehmen. Der Schwierigkeitsgrad der Aufgaben nimmt
Einführung in die Programmierung. (K-)II/Wb17
Probeklausur Hochschule Zittau/Görlitz, Prüfer: Prof. Dr. Georg Ringwelski Einführung in die Programmierung (K-)II/Wb17 Matrikelnummer: Punkte: 1 2 3 4 5 6 Gesamt /21 /19 /20 /20 /20 /20 /120 Spielregeln:
Probeklausur Java Einführung in die Informatik. Wintersemester 2014/2015
Fakultät IV NI & CV Probeklausur Java Einführung in die Informatik Wintersemester 2014/2015 Hinweis: Diese Probeklausur ist eine kleine Aufgabensammlung, die etwa dem Schwierigkeitsgrad der schriftlichen
Vererbung P rogram m ieren 2 F örster/r iedham m er K apitel 11: V ererbung 1
Vererbung 1 11.1 Motivation und Begriffsdefinitionen 11.2 Vorgehensweise und Implementierung 11.3 Arten von Vererbung 11.4 Konstruktoren 11.5 Abstrakte Klasse 11.6 Verschattung 11.7 Wurzelklasse Object
Programmieren I. Kapitel 5. Kontrollfluss
Programmieren I Kapitel 5. Kontrollfluss Kapitel 5: Kontrollfluss Ziel: Komplexere Berechnungen im Methodenrumpf Ausdrücke und Anweisungen Fallunterscheidungen (if, switch) Wiederholte Ausführung (for,
Objektorientierte Programmierung Studiengang Medieninformatik
Objektorientierte Programmierung Studiengang Medieninformatik Hans-Werner Lang Hochschule Flensburg Vorlesung 1 15.03.2017 Objektorientierte Programmierung (Studiengang Medieninformatik) Form: Prüfung:
PROCESSING EINE ZUSAMMENFASSUNG. Created by Michael Kirsch & Beat Rossmy
PROCESSING EINE ZUSAMMENFASSUNG Created by Michael Kirsch & Beat Rossmy INHALT 1. Typen und Operatoren 1. Datentypen 3. Klassen und Objekte 1. Klassen und Objekte 2. Operatoren 2. Konstruktor 3. Typkonversion
OOSE 01 JAVA MIT BLUEJ UND UML-BY-EXAMPLE
OOSE 01 JAVA MIT BLUEJ UND UML-BY-EXAMPLE Nutzung des AMCS (Auditorium Mobile Classroom Service) https://amcs.website Einloggen/Registrieren mit beliebigem Pseudonym Passwort Kurs Softwaretechnologie PIN:
Prof. Dr. Wolfgang Schramm. Vorlesung. Techniken der Programmentwicklung. Exkurs: Anonyme Klassen
Prof. Dr. Wolfgang Schramm Vorlesung Exkurs: Anonyme Klassen Techniken der Programmentwicklung Prof. Dr. Wolfgang Schramm Vorlesung Exkurs: Anonyme Klassen Techniken der Programmentwicklung Anonyme Klassen
Fakultät IV Elektrotechnik/Informatik
Fakultät IV Elektrotechnik/Informatik Probeklausur Einführung in die Informatik I Hinweis: Diese Probeklausur ist eine kleine Aufgabensammlung, die etwa dem Schwierigkeitsgrad der Teilleistung TL 2 (Programmiertest)
Klausur zur Vorlesung Informatik 1 im Wintersemester 2014/2015 am 18. Februar Bearbeitungszeit: 90 Minuten Gesamtpunktezahl: 90 Punkte
Universität Düsseldorf Mathematisch-naturwissenschaftliche Fakultät Institut für Informatik Prof. Dr. Michael Schöttner Florian Klein Kevin Beineke Janine Haas Klausur zur Vorlesung Informatik 1 im Wintersemester
