Software-Spezifikation
|
|
|
- Agnes Maya Dressler
- vor 10 Jahren
- Abrufe
Transkript
1 0/36 Software-Spezifikation Andreas Zeller Lehrstuhl Softwaretechnik Universität des Saarlandes, Saarbrücken
2 Spezifikation 1/36 Spezifikationsverfahren werden während der Software-Entwicklung eingesetzt, um die Semantik ausgewählter Funktionen zu beschreiben. In der Regel geschieht dies ohne Beteiligung des Kunden wenn der Grobentwurf (Systemmodell, Sequenzdiagramme) feststehen für ausgewählte (kritische, zentrale) Funktionen
3 Anforderungen 2/36 Jede Spezifikation soll vollständig sein jeder Aspekt des Systemverhaltens wird abgedeckt widerspruchsfrei sein damit klar ist, was implementiert werden soll auch unvorhergesehene Umstände beschreiben, um die Robustheit zu steigern.
4 Verfahren 3/36 Man unterscheidet folgende Spezifikationsverfahren: Informale Spezifikation in Prosa (natürlicher Sprache) Formale Spezifikation in spezieller Modellierungssprache Exemplarische Spezifikation mit Testfällen
5 Informale Spezifikation 4/36 Für jede Funktion wird in kurzer Prosa beschrieben, was sie xtut. Die Beschreibung sollte zumindest enthalten: den Zweck der Funktion die Rolle der Parameter und des Rückgabewertes ggf. Seiteneffekte Weitverbreitetes Spezifikationsverfahren Gut für Dokumentation geeignet Unexakt Einhaltung der Spezifikation schwer nachweisbar
6 Spezifikation einer Prozess-Steuerung 5/36 Einfache informale Spezifikation, gegliedert nach Klassen und Methoden: Klasse Control: int Control.get temperature() liefert die Temperatur des Reaktors in Grad Celsius zurück. boolean Control.(input output emergency) valve open() liefert true, wenn das betreffende Ventil geöffnet ist; sonst false. void Control.set (input output emergency) valve (boolean valve open) öffnet das betreffende Ventil, wenn valve open den Wert true hat; ansonsten wird das Ventil geschlossen. Hier werden mehrere ähnliche Methoden zu einem Muster zusammengefasst. Dies vermeidet Cut/Copy/Paste von immer wiederkehrenden Abschnitten.
7 UNIX-Funktion open 6/36 Das UNIX-Referenzhandbuch beschreibt für jede bereitgestellte Funktion, was sie tut: Name open open and possibly create a file or device Synopsys #include <sys/types.h> [...] int open(const char *pathname, int flags); Description The open() system call is used to convert a pathname into a file descriptor (a small, non-negative integer for use in subsequent I/O as with read, write, etc.). [... ] flags is one of O RDONLY, O WRONLY or O RDWR which request opening the file read-only, write-only or read/write, respectively. [... ] Return Value open returns the new file descriptor, or 1 if an error occurred (in which case, errno is set appropriately). [... ] Bewährtes und verbreitetes Schema!
8 Perl-Inkrement-Operator 7/36 Abschreckendes Beispiel: Spezifikation des Perl-++-Operators The autoincrement operator [++] has a little extra built-in magic. If you increment a variable that is numeric, or that has ever been used in a numeric context, you get a normal increment. If, however, the variable has only been used in string contexts since it was set, has a value that is not the null string, and matches the pattern /[a-za-z]*[0-9]*$/, the increment is done as a string, preserving each character within its range, with carry: print ++($foo = 99 ); # prints 100 print ++($foo = a9 ); # prints b0 print ++($foo = Az ); # prints Ba print ++($foo = zz ); # prints aaa Was ist ein Kontext? Werden Unicode-Strings ebenfalls inkrementiert? Wie? Was ist der Wert von $foo? Wenn Sie jemals ++ implementieren müssen: Viel Spass!
9 Formale Spezifikation 8/36 Mittels einer formalen Beschreibungssprache wird die Semantik der Funktionen exakt festgelegt. Exakte Beschreibung der Semantik Ausführbare Spezifikationssprache kann als Prototyp dienen Möglichkeit des Programmbeweises Erhöhte Anforderungen an Verwender Aufwendig
10 Spezifikation mit Bedingungen 9/36 In der Praxis werden komplexe Funktionen über Bedingungen spezifiziert: Vorbedingungen für Voraussetzungen Nachbedingungen für Wirkung Invarianten für Unveränderliches
11 Vorbedingungen 10/36 beschreiben die Voraussetzungen zur Ausführung einer Funktion. Hierzu gehören: Aussagen über die Eingabeparameter Aussagen über den Programmzustand (sichtbar und unsichtbar)
12 Nachbedingungen 11/36 beschreiben den Effekt, den die Ausführung einer Funktion bewirkt. Hierzu gehören: Aussagen über die Ausgabeparameter Aussagen über den Programmzustand jeweils in Abhängigkeit vom Vorzustand und den Eingabeparametern
13 Invarianten 12/36 sind Aussagen, die vor und nach jeder Funktion gelten typischerweise über Objekt- und Klassenzustände
14 Beispiel: Ein Editor in Z 13/36 Wir modellieren einen Texteditor mit zwei Dokumenten: left steht vor der aktuellen Cursor-Position, right ist danach. Die Gesamtlänge des Textes darf maxsize nie überschreiten. Zustand und Invariante werden durch ein Schema der Modellierungssprache Z beschrieben: Editor left, right : TEXT #(left right) maxsize : Konkatenation zweier Folgen #: Anzahl der Elemente
15 Beispiel: Ein Editor in Z (2) 14/36 Wir modellieren das Einfügen eines einzelnen Zeichens: Insert Editor ch? : CHAR ch? printing left = left ch? right = right Editor: Operations-Schema auf Editor ch?: Eingabevariable ch? printing: Vorbedingung ( Zeichen muss druckbar sein ) left, right : Zustand nach der Operation
16 Herausforderungen 15/36 Beweis zentraler Eigenschaften. Für jede Operation muss bewiesen werden, dass sie die Bedingungen einhält etwa die Invariante #(left right) maxsize Korrekte Konkretisierung. Beim Umsetzen in die endgültige Programmiersprache muss sichergestellt sein, dass Semantik (und somit die bewiesenen Eigenschaften) erhalten bleiben. Ergebnis: korrekte Software!
17 Statische vs. dynamische Prüfung 16/36 An Stelle der vollständigen Verifikation können auch Prüfungen zur Laufzeit treten. Beispiel: Prüft eine Funktion bei jedem Aufruf, ob ihre Vor- und Nachbedingungen erfüllt sind, ist per Definition die Korrektheit der Funktion gegeben wenn sie ein Ergebnis liefert.
18 Zusicherung 17/36 In der Praxis werden Bedingungen häufig zur Laufzeit geprüft! Praktische Anwendung mit Zusicherungen (assertions) assert(x) bricht die Ausführung ab, wenn x unwahr ist int square root(int a) { sqrt a =...; assert (a == sqrt a * sqrt a); return sqrt a; } Zusicherungen können komplett abgeschaltet werden (warum?)
19 Exemplarische Spezifikation 18/36 Durch Testfälle werden Beispiele für das Zusammenspiel der Funktionen samt erwarteter Ergebnisse beschrieben. Formales (da am Code orientiertes) Spezifikationsverfahren, dennoch leicht verständlich Nach der Implementierung dienen die Testfälle zur Validierung Nur exemplarische Beschreibung (und Validierung) des Verhaltens; muss mit zumindest informaler Spezifikation ergänzt werden.
20 Exemplarische Spezifikation (2) 19/36 Im Extreme Programming gilt der Leitsatz, dass so früh wie möglich getestet werden soll: Die Testfälle werden bereits vor der Implementierung erstellt Tritt ein neuer, noch nicht abgedeckter Fehler auf, wird vor der Fehlersuche ein Testfall erstellt, der den Fehler reproduziert. Die Testfälle werden so Teil der Spezifikation! Um Umstrukturierung (Refactoring) zu erleichtern, werden die Tests automatisiert; die Programmierer erstellen, verwalten die Tests selbst und führen sie auch aus (etwa nach jeder Änderung).
21 Automatisches Testen mit JUnit 20/36 JUnit von Kent Beck und Erich Gamma ist ein Testrahmen für Regressionstests von Java-Komponenten. Ziel von JUnit ist, die Produktion hochwertigen Codes zu beschleunigen. Analog: CPPUnit für C++-Programme
22 Testfälle 21/36 JUnit stellt Testfälle (Testcase) bereit, organisiert nach dem Command-Pattern. Ein Testfall besteht aus einer Menge von testxxx()-methoden, die jeweils einen bestimmten Test realisieren; mit der ererbten asserttrue()-methode werden erwartete Eigenschaften sichergestellt. Zusätzlich gibt es setup() zum Initialisieren einer (Test-)Umgebung (Attribute) sowie teardown() zum Freigeben der Testumgebung.
23 Testsuiten 22/36 Die Tests eines Testfalls werden in einer Testsuite (TestSuite) zusammengefasst, die von der Methode suite() zurückgegeben werden. Testsuiten können ebenfalls Testsuiten enthalten (Composite-Pattern).
24 Testen eines Warenkorbs 23/36 Die Klasse ShoppingCart (Warenkorb; hier nicht angegeben) enthält Methoden zum Hinzufügen und Löschen von Produkten sowie zum Abfragen der Produktanzahl und des Gesamtpreises. Wir implementieren einen Testfall als Klasse ShoppingCartTest, der die Funktionalität der Klasse testet.
25 Teil 1: Initialisierung 24/36 enthält Konstruktor sowie Erzeugen und Zerstören der Testumgebung import junit.framework.test; import junit.framework.testcase; import junit.framework.testsuite; public class ShoppingCartTest extends TestCase { private ShoppingCart bookcart; // Neuen Test erzeugen public ShoppingCartTest(String name) { super(name); }
26 Initialisierung (2) 25/36 // Testumgebung erzeugen // Wird vor jeder testxxx()-methode aufgerufen protected void setup() { bookcart = new ShoppingCart(); } Product book = new Product("Extreme Programming", 23.95); bookcart.additem(book); // Testumgebung wieder freigeben protected void teardown() { bookcart = null; }
27 Teil 2: Tests 26/36 Jeder Test wird als Methode public void testxxx() realisiert. Ein Test führt einige Methoden aus und prüft dann, ob der Zustand den Erwartungen entspricht. Wenn nicht, gibt es einen Fehler. Beispiel: Test auf leeren Warenkorb. Erst wird der Warenkorb geleert, dann wird geprüft, ob er auch tatsächlich leer ist. // Test auf leeren Warenkorb public void testempty() { bookcart.empty(); asserttrue( bookcart.isempty()); }
28 Tests (2) 27/36 Wir benutzen die von TestCase ererbten Hilfsmethoden: fail(msg) meldet einen Fehler namens msg asserttrue(msg, b) meldet einen Fehler, wenn Bedingung b unwahr ist assertequals(msg, v 1, v 2 ) meldet einen Fehler, wenn v 1 v 2 assertequals(msg, v 1, v 2, ɛ) meldet einen Fehler, wenn v 1 v 2 > ɛ assertnull(msg, object) meldet einen Fehler, wenn object nicht null ist assertnonnull(msg, object) meldet einen Fehler, wenn object null ist msg kann auch weggelassen werden.
29 Funktioniert das Hinzufügen? 28/36 // Test auf Hinzufügen public void testproductadd() { Product book = new Product("Refactoring", 53.95); bookcart.additem(book); } double expectedbalance = book.getprice(); double currentbalance = bookcart.getbalance(); double tolerance = 0.0; assertequals(expectedbalance, currentbalance, tolerance); int expecteditemcount = 2; int currentitemcount = bookcart.getitemcount(); assertequals(expecteditemcount, currentitemcount);
30 Funktioniert das Löschen? 29/36 // Test auf Löschen public void testproductremove() throws ProductNotFoundException { Product book = new Product("Extreme Programming", 23.95); bookcart.removeitem(book); } double expectedbalance = book.getprice(); double currentbalance = bookcart.getbalance(); double tolerance = 0.0; assertequals(expectedbalance, currentbalance, tolerance); int expecteditemcount = 0; int currentitemcount = bookcart.getitemcount(); assertequals(expecteditemcount, currentitemcount);
31 Gibt es korrekte Fehlerbehandlung? // Test auf Entfernen eines unbekannten Produkts public void testproductnotfound() { try { Product book = new Product("Ender s Game", 4.95); bookcart.removeitem(book); fail("should raise a ProductNotFoundException"); } catch(productnotfoundexception pnfe) { // Test sollte stets hier entlang laufen } } 30/36
32 Teil 3: Testsuite 31/36 Die Klasse wird mit einer Methode suite() abgeschlossen, die die einzelnen Testfälle zu einer Testsuite zusammenfasst. Dies geschieht gewöhnlich über Reflection alle Methoden der Form testxxx() werden Teil der Testsuite. // Testsuite erstellen public static Test suite() { } // Hier: Alle testxxx()-methoden hinzufügen (über Reflection) TestSuite suite = new TestSuite(ShoppingCartTest.class); // Alternative: Methoden einzeln hinzufügen (fehleranfällig) // TestSuite suite = new TestSuite(); // suite.addtest(new ShoppingCartTest("testEmpty"); // suite.addtest(new ShoppingCartTest("testProductAdd"); // suite.addtest(new ShoppingCartTest("testProductRemove"); // suite.addtest(new ShoppingCartTest("testProductNotFound"); return suite;
33 Teil 4: Hilfen 32/36 Schließlich müssen wir dem Testfall noch einen Namen geben (tostring()). Die Hauptmethode main() ruft ein GUI für genau diesen Testfall auf. } // String-Darstellung dieses Testfalls zurückgeben public String tostring() { return getname(); } // Hauptmethode: Ruft GUI auf public static void main(string args[]) { String[] testcasename = { ShoppingCartTest.class.getName() }; // junit.textui.testrunner.main(testcasename); junit.swingui.testrunner.main(testcasename); } Damit ist die Klasse ShoppingCartTest vollständig.
34 Test ausführen 33/36 Ist die Implementierung abgeschlossen, kann der Testfall zur Validierung benutzt werden indem er ausgeführt wird. Das Ausführen eines Testfalls geschieht einfach über die main()-methode, die (hier) eine graphische Oberfläche aufruft: $ java ShoppingCartTest Eine komplette TestSuite (aus mehreren Testfällen) wird ebenso ausgeführt: $ java EcommerceTestSuite
35 Test ausführen (2) 34/36 Die Testergebnisse werden im Fenster angezeigt:
36 Noch Fragen? 35/36 Welche Testfälle brauche ich? Die Testfälle sollten die Testfälle aus dem Pflichtenheft abdecken (soweit möglich) Die Testfälle sollten jede Methode der zu testenden Klasse wenigstens einmal aufrufen Enthält die Beschreibung der Methode unterschiedliches Verhalten für verschiedene Fälle, sollte jeder Fall einzeln getestet werden. Wann muss ich neu testen? Am besten automatisch nach jeder Änderung!
37 Checkliste: Spezifikation 36/36 Wir erwarten eine exemplarische Spezifikation der im Pflichtenheft aufgeführten Tests (die im Grobentwurf bereits als Sequenzdiagramme ausmodelliert sein sollten). Sind erwartete Ergebnisse dokumentiert? (z.b. mit Zusicherungen) Laufen die Tests automatisch ab? (z.b. in JUnit oder CPPUnit) Entsprechen die Tests den Szenarien im Grobentwurf (Sequenzdiagramme)? Entsprechen die Tests den Testszenarien im Pflichtenheft?
JUnit. Unit testing unter Java
JUnit Unit testing unter Java Was ist Junit? einfaches Framework zum Schreiben von wiederholbaren Tests Besonders geeignet für unit testing Erlaubt Hierarchie von Testsuites Schreiben eines Test Case 1.
Java: Vererbung. Teil 3: super() www.informatikzentrale.de
Java: Vererbung Teil 3: super() Konstruktor und Vererbung Kindklasse ruft SELBSTSTÄNDIG und IMMER zuerst den Konstruktor der Elternklasse auf! Konstruktor und Vererbung Kindklasse ruft SELBSTSTÄNDIG und
Einführung in die Programmierung
Technische Universität München WS 2003/2004 Institut für Informatik Prof. Dr. Christoph Zenger Testklausur Einführung in die Programmierung Probeklausur Java (Lösungsvorschlag) 1 Die Klasse ArrayList In
SEP 114. Design by Contract
Design by Contract SEP 114 Design by Contract Teile das zu entwickelnde Programm in kleine Einheiten (Klassen, Methoden), die unabhängig voneinander entwickelt und überprüft werden können. Einheiten mit
Testen mit JUnit. Motivation
Test First Design for Test in Eclipse (eigentlich: ) zu einer Klasse Beispiel zur Demonstration Ergänzungen Test First "Immer dann, wenn Du in Versuchung kommst, etwas wie eine print- Anweisung oder einen
Einführung in die Java- Programmierung
Einführung in die Java- Programmierung Dr. Volker Riediger Tassilo Horn riediger [email protected] WiSe 2012/13 1 Wichtig... Mittags keine Pommes... Praktikum A 230 C 207 (Madeleine + Esma) F 112 F 113
Design by Contract with JML
Thema: Design by Contract with JML Proseminar: Assertions Verfasser: Literatur: Betreuer: Natalya Moriz Gary T.Leavens and Yoonsik Cheon: Design by Contract with JML Prof. Dr. Heike Wehrheim 1 Inhalt DBC
Objektorientierte Programmierung
Objektorientierte Programmierung 1 Geschichte Dahl, Nygaard: Simula 67 (Algol 60 + Objektorientierung) Kay et al.: Smalltalk (erste rein-objektorientierte Sprache) Object Pascal, Objective C, C++ (wiederum
Fachgebiet Informationssysteme Prof. Dr.-Ing. N. Fuhr. Programmierung Prof. Dr.-Ing. Nobert Fuhr. Übungsblatt Nr. 6
Gudrun Fischer Sascha Kriewel [email protected] Anmeldung zur Klausur! Übungsblatt Nr. 6 Um an der Klausur teilzunehmen, müssen sich Studierende der angewandten Informatik in
Zählen von Objekten einer bestimmten Klasse
Zählen von Objekten einer bestimmten Klasse Ziel, Inhalt Zur Übung versuchen wir eine Klasse zu schreiben, mit der es möglich ist Objekte einer bestimmten Klasse zu zählen. Wir werden den ++ und den --
Übungen zu Einführung in die Informatik: Programmierung und Software-Entwicklung: Lösungsvorschlag
Ludwig-Maximilians-Universität München WS 2015/16 Institut für Informatik Übungsblatt 9 Prof. Dr. R. Hennicker, A. Klarl Übungen zu Einführung in die Informatik: Programmierung und Software-Entwicklung:
Software-Engineering Software-Management
Software-Engineering Software-Management 12.3 Unit-Tests mit JUnit - Wissen, was der Sourcecode macht! Lösung Prof. Dr. Rolf Dornberger Software-Engineering: 12.3 Unit-Tests mit JUnit 30.04.2006 1 12.3
5. Tutorium zu Programmieren
5. Tutorium zu Programmieren Dennis Ewert Gruppe 6 Universität Karlsruhe Institut für Programmstrukturen und Datenorganisation (IPD) Lehrstuhl Programmierparadigmen WS 2008/2009 c 2008 by IPD Snelting
1 Vom Problem zum Programm
Hintergrundinformationen zur Vorlesung GRUNDLAGEN DER INFORMATIK I Studiengang Elektrotechnik WS 02/03 AG Betriebssysteme FB3 Kirsten Berkenkötter 1 Vom Problem zum Programm Aufgabenstellung analysieren
Test-Driven Design: Ein einfaches Beispiel
Test-Driven Design: Ein einfaches Beispiel Martin Wirsing in Zusammenarbeit mit Moritz Hammer und Axel Rauschmayer SS 06 2 Ziele Veranschaulichung der Technik des Test-Driven Design am Beispiel eines Programms
Programmierkurs Java
Programmierkurs Java Dr. Dietrich Boles Aufgaben zu UE16-Rekursion (Stand 09.12.2011) Aufgabe 1: Implementieren Sie in Java ein Programm, das solange einzelne Zeichen vom Terminal einliest, bis ein #-Zeichen
Programmiertechnik II
Modultests Ziele Überprüfung der Korrektheit eines Moduls Korrektheit: Übereinstimmung mit (informaler) Spezifikation Modul: kleine testbare Einheit (Funktion, Klasse) Engl.: unit test White box testing
Programmieren in Java
Programmieren in Java objektorientierte Programmierung 2 2 Zusammenhang Klasse-Datei In jeder *.java Datei kann es genau eine public-klasse geben wobei Klassen- und Dateiname übereinstimmen. Es können
Downloadfehler in DEHSt-VPSMail. Workaround zum Umgang mit einem Downloadfehler
Downloadfehler in DEHSt-VPSMail Workaround zum Umgang mit einem Downloadfehler Downloadfehler bremen online services GmbH & Co. KG Seite 2 Inhaltsverzeichnis Vorwort...3 1 Fehlermeldung...4 2 Fehlerbeseitigung...5
Fakultät Angewandte Informatik Lehrprofessur für Informatik 23.01.2012
WS 2011/2012 Fakultät Angewandte Informatik Lehrprofessur für Informatik 23.01.2012 Prof. Dr. Robert Lorenz Musterlösung zur Vorlesung Informatik I, Extrablatt zu komplexen Datenstrukturen Aufgabe 45 **
Große Übung Praktische Informatik 1
Große Übung Praktische Informatik 1 2005-12-08 [email protected] http://www.informatik.uni-mannheim.de/pi4/people/fuessler 1: Announcements / Orga Weihnachtsklausur zählt als Übungsblatt,
Client-Server-Beziehungen
Client-Server-Beziehungen Server bietet Dienste an, Client nutzt Dienste Objekt ist gleichzeitig Client und Server Vertrag zwischen Client und Server: Client erfüllt Vorbedingungen eines Dienstes Server
Übung Grundlagen der Programmierung. Übung 03: Schleifen. Testplan Testergebnisse
Übung 03: Schleifen Abgabetermin: xx.xx.xxxx Name: Matrikelnummer: Gruppe: G1 (Prähofer) G2 (Prähofer) G3 (Wolfinger) Aufgabe Punkte gelöst abzugeben schriftlich abzugeben elektronisch Aufgabe 03.1 12
WPF Steuerelemente Listbox, ComboBox, ListView,
WPF Steuerelemente Listbox, ComboBox, ListView, Dr. Beatrice Amrhein Überblick Einführung Listen ComboBox Tabellen 2 Einführung 3 Listen- und Tabellen-Elemente Listen und Tabellen-Elemente sind Steuerelemente,
Übungen zu Einführung in die Informatik: Programmierung und Software-Entwicklung: Lösungsvorschlag
Ludwig-Maximilians-Universität München WS 2015/16 Institut für Informatik Übungsblatt 13 Prof. Dr. R. Hennicker, A. Klarl Übungen zu Einführung in die Informatik: Programmierung und Software-Entwicklung:
Computeranwendung und Programmierung (CuP)
Computeranwendung und Programmierung (CuP) VO: Peter Auer (Informationstechnologie) UE: Norbert Seifter (Angewandet Mathematik) Organisatorisches (Vorlesung) Vorlesungszeiten Montag 11:15 12:45 Freitag
Dokumentation des Projektes Tic Tac Toe
Praktikum aus Programmierung Dr. Michael Hahsler Dokumentation des Projektes Tic Tac Toe 0050230 1 Java Projekt: Tic Tac Toe 1. Inhaltsverzeichnis 1. Inhaltsverzeichnis... 2 2. Problemdefinition... 2 3.
Komponententest. Testen von Software Systemen. Übung 02 SS 2009 Version: 1.0 09.06.2009
Testen von Software Systemen Übung 02 SS 2009 Version: 1.0 09.06.2009 Komponententest Kunde: Dr. Reinhold Plösch Dr. Johannes Sametinger Kundenreferenz: 259.019 Team 19 Mitarbeiter: Christian Märzinger
Matrix42. Use Case - Sicherung und Rücksicherung persönlicher Einstellungen über Personal Backup. Version 1.0.0. 23. September 2015 - 1 -
Matrix42 Use Case - Sicherung und Rücksicherung persönlicher Version 1.0.0 23. September 2015-1 - Inhaltsverzeichnis 1 Einleitung 3 1.1 Beschreibung 3 1.2 Vorbereitung 3 1.3 Ziel 3 2 Use Case 4-2 - 1 Einleitung
Java Kurs für Anfänger Einheit 5 Methoden
Java Kurs für Anfänger Einheit 5 Methoden Ludwig-Maximilians-Universität München (Institut für Informatik: Programmierung und Softwaretechnik von Prof.Wirsing) 22. Juni 2009 Inhaltsverzeichnis Methoden
2015-06-11 Tagesprogramm
1 2015-06-11 Tagesprogramm Design-by-Contract 2 Vertragspartner Anbieter (Server) bietet Leistungen (Services) an Kunde (Client) nimmt von Anbietern angebotene Leistungen in Anspruch Details der Inanspruchnahme
Daniel Warneke [email protected] 08.05.2006. Ein Vortrag im Rahmen des Proseminars Software Pioneers
Design Patterns Daniel Warneke [email protected] 08.05.2006 Ein Vortrag im Rahmen des Proseminars Software Pioneers Design Patterns 1/23 Übersicht Einleitung / Motivation Design Patterns Beispiele Rolle des
Programmieren für Ingenieure Sommer 2015. Ein Rechner. Rechner sind überall. Gerät, das mittels programmierbarer Rechenvorschriften Daten verarbeitet.
Programmieren für Ingenieure Sommer 2015 Andreas Zeller, Universität des Saarlandes Ein Rechner Gerät, das mittels programmierbarer Rechenvorschriften Daten verarbeitet. Rechner sind überall Ihr Rechner
Institut für Programmierung und Reaktive Systeme 25. August 2014. Programmier-Labor. 04. + 05. Übungsblatt. int binarysearch(int[] a, int x),
Technische Universität Braunschweig Dr. Werner Struckmann Institut für Programmierung und Reaktive Systeme 25. August 2014 Programmier-Labor 04. + 05. Übungsblatt Aufgabe 21: a) Schreiben Sie eine Methode
Import des Out of Office Status von Exchange in LANDESK Service Desk
LANDESK Tech Tipp April 2016 Import des Out of Office Status von Exchange in LANDESK Service Desk Sie möchten einem Kollegen aus der IT-Abteilung einen Incident zuweisen, der keines Falls liegen bleiben
Einführung in die Informatik Tools
Einführung in die Informatik Tools Werkzeuge zur Erstellung von Softwareprojekten Wolfram Burgard 8.1 Motivation Große Softwareprojekte werden schnell unübersichtlich. Änderungen im Code können leicht
JUnit - Test Driven Development. Bernhard Frey, Thorsten Stratmann, Jackson Takam, Michel Müller 1
JUnit - Test Driven Development Bernhard Frey, Thorsten Stratmann, Jackson Takam, Michel Müller 1 Gliederung 1.Einleitung 1.1 Geschichte 1.2 Was sind Unit-Tests? 1.3 Failures/Errors 1.4 Ziele und Nutzen
Grundlagen der Programmierung Prof. H. Mössenböck. 14. Schrittweise Verfeinerung
Grundlagen der Programmierung Prof. H. Mössenböck 14. Schrittweise Verfeinerung Entwurfsmethode für Algorithmen Wie kommt man von der Aufgabenstellung zum Programm? Beispiel geg.: Text aus Wörtern ges.:
Das Test-Framework JUnit ETIS SS04
Das Test-Framework JUnit ETIS SS04 Gliederung Motivation TestFirst Grundlagen Assert TestCase Lebenszyklus TestCase UML-Diagramm TestCase TestSuite Zusammenfassung 2 Motivation (I) Kostspielige Folgen
Unterprogramme. Funktionen. Bedeutung von Funktionen in C++ Definition einer Funktion. Definition einer Prozedur
Unterprogramme Unterprogramme sind abgekapselte Programmfragmente, welche es erlauben, bestimmte Aufgaben in wiederverwendbarer Art umzusetzen. Man unterscheidet zwischen Unterprogrammen mit Rückgabewert
Delegatesund Ereignisse
Delegatesund Ereignisse «Delegierter» Methoden Schablone Funktionszeiger Dr. Beatrice Amrhein Überblick Definition eines Delegat Einfache Delegate Beispiele von Delegat-Anwendungen Definition eines Ereignisses
Vorkurs C++ Programmierung
Vorkurs C++ Programmierung Klassen Letzte Stunde Speicherverwaltung automatische Speicherverwaltung auf dem Stack dynamische Speicherverwaltung auf dem Heap new/new[] und delete/delete[] Speicherklassen:
Software Engineering. Zur Architektur der Applikation Data Repository. Franz-Josef Elmer, Universität Basel, HS 2015
Software Engineering Zur Architektur der Applikation Data Repository Franz-Josef Elmer, Universität Basel, HS 2015 Software Engineering: Mit acht bewährten Praktiken zu gutem Code 2 Schichtarchitektur
Java Kurs für Anfänger Einheit 4 Klassen und Objekte
Java Kurs für Anfänger Einheit 4 Klassen und Ludwig-Maximilians-Universität München (Institut für Informatik: Programmierung und Softwaretechnik von Prof.Wirsing) 13. Juni 2009 Inhaltsverzeichnis klasse
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
Der Aufruf von DM_in_Euro 1.40 sollte die Ausgabe 1.40 DM = 0.51129 Euro ergeben.
Aufgabe 1.30 : Schreibe ein Programm DM_in_Euro.java zur Umrechnung eines DM-Betrags in Euro unter Verwendung einer Konstanten für den Umrechnungsfaktor. Das Programm soll den DM-Betrag als Parameter verarbeiten.
Erweiterung der Aufgabe. Die Notenberechnung soll nicht nur für einen Schüler, sondern für bis zu 35 Schüler gehen:
VBA Programmierung mit Excel Schleifen 1/6 Erweiterung der Aufgabe Die Notenberechnung soll nicht nur für einen Schüler, sondern für bis zu 35 Schüler gehen: Es müssen also 11 (B L) x 35 = 385 Zellen berücksichtigt
Mediator 9 - Lernprogramm
Mediator 9 - Lernprogramm Ein Lernprogramm mit Mediator erstellen Mediator 9 bietet viele Möglichkeiten, CBT-Module (Computer Based Training = Computerunterstütztes Lernen) zu erstellen, z. B. Drag & Drop
Programmierkurs Java
Programmierkurs Java Konstruktor, Statische Methoden Packages Prof. Dr. Stefan Fischer Institut für Telematik, Universität zu Lübeck http://www.itm.uni-luebeck.de/people/fischer Initialisierung von Datenstrukturen
Lineargleichungssysteme: Additions-/ Subtraktionsverfahren
Lineargleichungssysteme: Additions-/ Subtraktionsverfahren W. Kippels 22. Februar 2014 Inhaltsverzeichnis 1 Einleitung 2 2 Lineargleichungssysteme zweiten Grades 2 3 Lineargleichungssysteme höheren als
Verhindert, dass eine Methode überschrieben wird. public final int holekontostand() {...} public final class Girokonto extends Konto {...
PIWIN I Kap. 8 Objektorientierte Programmierung - Vererbung 31 Schlüsselwort: final Verhindert, dass eine Methode überschrieben wird public final int holekontostand() {... Erben von einer Klasse verbieten:
Handbuch für Redakteure
Handbuch für Redakteure Erste Schritte... 1 Artikel erstellen... 2 Artikelinhalt bearbeiten... 3 Artikel bearbeiten... 3 Grunddaten ändern... 5 Weitere Artikeleigenschaften... 5 Der WYSIWYG-Editor... 6
14.4.2016. Technische Hochschule Georg Agricola WORKSHOP TEIL 3. IKT (Informations- und Kommunikationstechnik) an einer MorseApp erklärt
14.4.2016 Technische Hochschule Georg Agricola WORKSHOP TEIL 3 IKT (Informations- und Kommunikationstechnik) an einer MorseApp erklärt Inhaltsverzeichnis 1. Kurzfassung zur Projekterstellung... 2 2. Morse-Tabelle...
Das Typsystem von Scala. L. Piepmeyer: Funktionale Programmierung - Das Typsystem von Scala
Das Typsystem von Scala 1 Eigenschaften Das Typsystem von Scala ist statisch, implizit und sicher 2 Nichts Primitives Alles ist ein Objekt, es gibt keine primitiven Datentypen scala> 42.hashCode() res0:
AGROPLUS Buchhaltung. Daten-Server und Sicherheitskopie. Version vom 21.10.2013b
AGROPLUS Buchhaltung Daten-Server und Sicherheitskopie Version vom 21.10.2013b 3a) Der Daten-Server Modus und der Tresor Der Daten-Server ist eine Betriebsart welche dem Nutzer eine grosse Flexibilität
Objektorientierte Programmierung. Kapitel 12: Interfaces
12. Interfaces 1/14 Objektorientierte Programmierung Kapitel 12: Interfaces Stefan Brass Martin-Luther-Universität Halle-Wittenberg Wintersemester 2012/13 http://www.informatik.uni-halle.de/ brass/oop12/
Thermoguard. Thermoguard CIM Custom Integration Module Version 2.70
Thermoguard Thermoguard CIM Custom Integration Module Version 2.70 Inhalt - Einleitung... 3 - Voraussetzungen... 3 - Aktivierung und Funktion der Schnittstelle... 3 - Parameter... 4 - NLS-Einfluss... 4
5. Abstrakte Klassen. Beispiel (3) Abstrakte Klasse. Beispiel (2) Angenommen, wir wollen die folgende Klassenhierarchie implementieren:
5. Abstrakte Klassen Beispiel 5. Abstrakte Klassen 5. Abstrakte Klassen Beispiel Beispiel (3) Angenommen, wir wollen die folgende Klassenhierarchie implementieren: Probleme des Implementierungsvorschlags:
Einführung in Javadoc
Einführung in Javadoc Johannes Rinn http://java.sun.com/j2se/javadoc Was ist Javadoc? Javadoc ist ein Werkzeug, dass eine standardisierte Dokumentation für die Programmiersprache Java unterstützt. Vorteil:
Handbuch. Artologik EZ-Equip. Plug-in für EZbooking version 3.2. Artisan Global Software
Artologik EZ-Equip Plug-in für EZbooking version 3.2 Artologik EZbooking und EZ-Equip EZbooking, Ihre webbasierte Software zum Reservieren von Räumen und Objekten, kann nun durch die Ergänzung um ein oder
1 Mathematische Grundlagen
Mathematische Grundlagen - 1-1 Mathematische Grundlagen Der Begriff der Menge ist einer der grundlegenden Begriffe in der Mathematik. Mengen dienen dazu, Dinge oder Objekte zu einer Einheit zusammenzufassen.
Viele Bilder auf der FA-Homepage
Viele Bilder auf der FA-Homepage Standardmäßig lassen sich auf einer FA-Homepage nur 2 Bilder mit zugehörigem Text unterbringen. Sollen es mehr Bilder sein, muss man diese als von einer im Internet
Institut für Programmierung und Reaktive Systeme 26. April 2013. Programmieren II. 10. Übungsblatt
Technische Universität Braunschweig Dr. Werner Struckmann Institut für Programmierung und Reaktive Systeme 26. April 2013 Programmieren II 10. Übungsblatt Hinweis: Insgesamt werden in diesem Semester fünf
Erstellen einer Collage. Zuerst ein leeres Dokument erzeugen, auf dem alle anderen Bilder zusammengefügt werden sollen (über [Datei] > [Neu])
3.7 Erstellen einer Collage Zuerst ein leeres Dokument erzeugen, auf dem alle anderen Bilder zusammengefügt werden sollen (über [Datei] > [Neu]) Dann Größe des Dokuments festlegen beispielsweise A4 (weitere
188.154 Einführung in die Programmierung für Wirtschaftsinformatik
Beispiel 1 Vererbung (Liste) Gegeben sind die beiden Klassen ListNode und PersonNode. 188.154 Einführung in die Programmierung für Wirtschaftsinformatik Wiederholung, Prüfungsvorbereitung Monika Lanzenberger
NODELOCKED LIZENZ generieren (ab ST4)
NODELOCKED LIZENZ generieren () Besuchen Sie folgende Webseite support.ugs.com/global/de ( ohne www oder http:// ) Klicken Sie auf Lizenz Verwaltung und dann auf aktuelle Lizenz 1 1. Geben Sie Ihren Webkey
Grundlagen der Theoretischen Informatik, SoSe 2008
1. Aufgabenblatt zur Vorlesung Grundlagen der Theoretischen Informatik, SoSe 2008 (Dr. Frank Hoffmann) Lösung von Manuel Jain und Benjamin Bortfeldt Aufgabe 2 Zustandsdiagramme (6 Punkte, wird korrigiert)
Einführung in die Programmierung
: Inhalt Einführung in die Programmierung Wintersemester 2008/09 Prof. Dr. Günter Rudolph Lehrstuhl für Algorithm Engineering Fakultät für Informatik TU Dortmund - mit / ohne Parameter - mit / ohne Rückgabewerte
CodeSaver. Vorwort. Seite 1 von 6
CodeSaver Vorwort Die Flut der Passwörter nimmt immer mehr zu. Kontopasswörter, Passwörter für Homepages, Shellzugriffe, Registrierungscodes für Programme und und und. Da ich aber nicht sonderlich viel
Software Engineering Klassendiagramme Einführung
Software Engineering Klassendiagramme Einführung Prof. Adrian A. Müller, PMP, PSM 1, CSM Fachbereich Informatik und Mikrosystemtechnik 1 Aufgabe Erstellen Sie eine Klasse Person in Java. Jede Person verfügt
Visual Basic Express erstes Projekt anlegen
Inhalt Dokument Beschreibung... 1 Erstes Projekt anlegen... 1 Verweise hinzufügen... 2 Imports setzen... 5 Public Class vorbereiten... 6 Mehrere Tools programmieren... 7 Dokument Beschreibung Nach der
Objektorientierte Programmierung
Universität der Bundeswehr Fakultät für Informatik Institut 2 Priv.-Doz. Dr. Lothar Schmitz FT 2006 Zusatzaufgaben Lösungsvorschlag Objektorientierte Programmierung Lösung 22 (Java und UML-Klassendiagramm)
2A Basistechniken: Weitere Aufgaben
2A Basistechniken: Weitere Aufgaben 2A.3 Programmierung unter UNIX/Linux 1. Gegeben sind einige Ausschnitte von C-Programmen, die unter UNIX/Linux ausgeführt werden sollen. Beantworten Sie die zugehörigen
U08 Entwurfsmuster (II)
U08 Entwurfsmuster (II) Inhalt der Übung Diskussion und Implementierung von Entwurfsmustern Übungsaufgaben Aufgabe 1 (Queue) Gegeben ist das folgende Analysemodell einer Warteschlange (Queue): Eine Warteschlange
Algorithmen und Datenstrukturen
Algorithmen und Datenstrukturen Tafelübung 04 Referenzen, Overloading, Klassen(hierarchien) Clemens Lang T2 18. Mai 2010 14:00 16:00, 00.152 Tafelübung zu AuD 1/13 Organisatorisches Nächster Übungstermin
Dieses Tutorial gibt eine Übersicht der Form Klassen von Struts, welche Besonderheiten und Unterschiede diese aufweisen.
Übersicht Struts Forms Dieses Tutorial gibt eine Übersicht der Form Klassen von Struts, welche Besonderheiten und Unterschiede diese aufweisen. Allgemeines Autor: Sascha Wolski http://www.laliluna.de/tutorials.html
Folge 18 - Vererbung
Workshop Folge 18 - Vererbung 18.1 Ein einfacher Fall der Vererbung Schritt 1 - Vorbereitungen Besorgen Sie sich - vielleicht aus einer der Übungen der Folge 17 - ein fertiges und lauffähiges Listenprojekt,
Diplomarbeit. Konzeption und Implementierung einer automatisierten Testumgebung. Thomas Wehrspann. 10. Dezember 2008
Konzeption und Implementierung einer automatisierten Testumgebung, 10. Dezember 2008 1 Gliederung Einleitung Softwaretests Beispiel Konzeption Zusammenfassung 2 Einleitung Komplexität von Softwaresystemen
Enigmail Konfiguration
Enigmail Konfiguration 11.06.2006 [email protected] Enigmail ist in der Grundkonfiguration so eingestellt, dass alles funktioniert ohne weitere Einstellungen vornehmen zu müssen. Für alle, die es
Vererbung & Schnittstellen in C#
Vererbung & Schnittstellen in C# Inhaltsübersicht - Vorüberlegung - Vererbung - Schnittstellenklassen - Zusammenfassung 1 Vorüberlegung Wozu benötigt man Vererbung überhaubt? 1.Um Zeit zu sparen! Verwendung
Klassenentwurf. Wie schreiben wir Klassen, die leicht zu verstehen, wartbar und wiederverwendbar sind? Objektorientierte Programmierung mit Java
Objektorientierte Programmierung mit Java Eine praxisnahe Einführung mit BlueJ Klassenentwurf Wie schreiben wir Klassen, die leicht zu verstehen, wartbar und wiederverwendbar sind? 1.0 Zentrale Konzepte
Programmiervorkurs SS 2011 Technische Universität Darmstadt Jan Hendrik Burdinski, Felix Kerger http://www.d120.de/vorkurs.
Programmiervorkurs SS 2011 Technische Universität Darmstadt Jan Hendrik Burdinski, Felix Kerger http:www.d120.de/vorkurs Aufgabenblatt 3 Du findest zur Bearbeitung dieses Aufgabenblatts zu einigen Aufgaben
Grundlagen von Python
Einführung in Python Grundlagen von Python Felix Döring, Felix Wittwer November 17, 2015 Scriptcharakter Programmierparadigmen Imperatives Programmieren Das Scoping Problem Objektorientiertes Programmieren
Software Engineering Interaktionsdiagramme
Software Engineering Interaktionsdiagramme Prof. Adrian A. Müller, PMP, PSM 1, CSM Fachbereich Informatik und Mikrosystemtechnik 1 Nachrichtenaustausch Welche Nachrichten werden ausgetauscht? (Methodenaufrufe)
Problemstellung. Informatik B - Objektorientierte Programmierung in Java. Vorlesung 24: Reflection 1. IDE und automatische Tests.
Universität Osnabrück 1 Problemstellung 3 - Objektorientierte Programmierung in Java Vorlesung 24: Reflection 1 SS 2006 Prof. Dr. Frank M. Thiesing, FH Osnabrück Um ein Objekt anzulegen, eine seiner Methoden
Swp08-6 Verantwortliche: Yundensuren, Baigalmaa. Testkonzept
Testkonzept 1.Einführung Um die Zuverläsigkeit und die Qualität der Software und des gesamten Systems zu verbessern, sind Tests durchzuführen. Die Testreihe läst sich in drei Stufen einteilen, nülich Komponententest,
5. Abstrakte Klassen
5. Abstrakte Klassen Beispiel 5. Abstrakte Klassen Angenommen, wir wollen die folgende Klassenhierarchie implementieren: Vogel Amsel Drossel Fink Peter Becker, Programiersprache Java FH Bonn-Rhein-Sieg,
S7-Hantierungsbausteine für R355, R6000 und R2700
S7-Hantierungsbausteine für R355, R6000 und R2700 1. FB90, Zyklus_R/W Dieser Baustein dient zur zentralen Kommunikation zwischen Anwenderprogramm und dem Modul R355 sowie den Geräten R6000 und R2700 über
Testklausur 1 zur Vorlesung. Modellierung und Programmierung I. Dr. Monika Meiler Zeit: 60 Minuten
Matrikelnummer: Punkte: Testklausur 1 zur Vorlesung Modellierung und Programmierung I Dr. Monika Meiler Zeit: 60 Minuten Bemerkungen: Jedes Blatt ist mit der Matrikelnummer zu versehen. Jede Aufgabe ist
Übung 1 mit C# 6.0 MATTHIAS RONCORONI
Übung 1 mit C# 6.0 MATTHIAS RONCORONI Inhalt 2 1. Überblick über C# 2. Lösung der Übung 1 3. Code 4. Demo C# allgemein 3 aktuell: C# 6.0 mit.net-framework 4.6: Multiparadigmatisch (Strukturiert, Objektorientiert,
Softwarelösungen: Versuch 4
Softwarelösungen: Versuch 4 Nichtstun in Schleife wird ersetzt durch zeitweilige Zurücknahme der Anforderung, um es anderen Prozessen zu erlauben, die Ressource zu belegen: /* Prozess 0 */ wiederhole flag[0]
Softwareentwicklungspraktikum Sommersemester 2007. Grobentwurf
Softwareentwicklungspraktikum Sommersemester 2007 Grobentwurf Auftraggeber Technische Universität Braunschweig
Programmierkurs Java
Programmierkurs Java Dr. Dietrich Boles Aufgaben zu UE22-NutzungVonKlassen (Stand 28.09.2012) Aufgabe 1: Entwickeln Sie in Eclipse auf der Basis der vorgestellten Java-GUI-Klassen ein Java- Programm, das
Übung: Verwendung von Java-Threads
Übung: Verwendung von Java-Threads Ziel der Übung: Diese Übung dient dazu, den Umgang mit Threads in der Programmiersprache Java kennenzulernen. Ein einfaches Java-Programm, das Threads nutzt, soll zum
Einführung in die Programmierung (EPR)
Goethe-Center for Scientific Computing (G-CSC) Goethe-Universität Frankfurt am Main Einführung in die Programmierung (EPR) (Übung, Wintersemester 2014/2015) Dr. S. Reiter, M. Rupp, Dr. A. Vogel, Dr. K.
