GI-FG-2.1.9: AK Frameworks Framework-Dokumentation mit Entwurfsmustern

Slides:



Advertisements
Ähnliche Präsentationen
interaktiver Web Service Workflows
Advertisements

Benutzerorientierte Designprinzipien für die Microsoft-Guidelines
Konzepte des Anfangsunterrichts Informatik in der 11.1
Programmieren im Großen von Markus Schmidt und Benno Kröger.
Pop Jazz C B A Jazz C A Lehrstuhl für Künstliche Intelligenz
Strategie (Strategy / Policy) Ein objektbasiertes Verhaltensmuster Stephan Munkelt, Stefan Salzmann - 03IN.
Von David Keß, Heinrich Wölk, Daniel Hauck
On the Criteria to Be Used in Decomposing Systems into Modules
Designing Software for Ease of Extension and Contraction
Einführung in Cocoa Re-usable Content in 3D und Simulationssystemen Prof. Dr. Manfred Thaller, SS 2012 Do, Uhr, Archäologie-Pool Referent: Nelson.
Bastian Cramer, Universität Paderborn Entwurfsmuster für Webanwendungen Projektgruppe: Generierung von Webanwendungen aus visuellen Spezifikationen.
Untersuchung und szenariobasierte Entwicklung von Websites zur Orientierung in Universitätsstudiengängen unter Berücksichtigung von Prinzipien des Web.
NATURAL Web-Integration 1 / 27/28-Feb-98 TST NATURAL Web-Integration Arbeitskreis NATURAL Süd Theo Straeten SAG Systemhaus GmbH Technologieberater Stuttgart.
Objektorientierter Entwurf (OOD) Teil 3: Qualitätsmodell
Stefanie Selzer - Pascal Busch - Michael Kropiwoda
Universität Stuttgart Institut für Kernenergetik und Energiesysteme Was ist Refactoring? Bevor man die Integration angeht, mag es angebracht sein, den.
es gibt (fast) nichts, was nicht anders gemacht werden könnte
Java: Objektorientierte Programmierung
Internetstruktur Das Internet besteht aus vielen Computern, die weltweit untereinander vernetzt sind.
Praktikum Entwicklung und Einsatz von Geosoftware I - Sitzung 5 Polymorphismus Sommersemester 2003 Lars Bernard.
Einsatz von XML zur Kontextspeicherung in einem agentenbasierten ubiquitären System Faruk Bagci, Jan Petzold, Wolfgang Trumler und Theo Ungerer Lehrstuhl.
Sebastian Grahn Sebastian Kühn
Das Strukturmuster Kompositum von C. Günther, T. Hammerschmidt und D. Kuhn.
PKJ 2005/1 Stefan Dissmann Rückblick auf 2005 Was zuletzt in 2005 vorgestellt wurde: Klassen mit Attributen, Methoden und Konstruktoren Referenzen auf.
Vorlesung 3: Verschiedenes Universität Bielefeld – Technische Fakultät AG Rechnernetze und verteilte Systeme Peter B. Ladkin
Explizite und editierbare Metainformationen für Software Muster.
-LABORPRAKTIKUM- SOMMERSEMESTER 2005
Dependents, Publish-Subscribe, Listener
Entwurfsmuster EDV Entwurfsmuster.
OO Analyse und Entwurf für Anwender XIII. Objektorientierte Benutzeroberfäche Dr. Michael Löwe.
OO Analyse und Entwurf für Anwender
Grundschutztools
1 Vorlesung 3 Verschiedenes Peter B. Ladkin
UML Begleitdokumentation des Projekts
Forschungszentrum Informatik, Karlsruhe Objektorientierte Systeme unter der Lupe Markus Bauer Oliver Ciupke.
Neue sächsische Lehrpläne
PRJ 2007/1 Stefan Dissmann Verkettete datenstruktur: Liste Problem: Liste, die eine beliebige Zahl von Elementen verwaltet Operationen: Erzeugen, Anfügen,
Simulation komplexer technischer Anlagen
12. Vorlesung: Aktivitätsdiagramme
Delphi II - OOP IFB Fortbildung
Telecooperation/RBG Technische Universität Darmstadt Copyrighted material; for TUD student use only Grundlagen der Informatik I Thema 14: Schrittweise.
EXCEL PROFESSIONAL KURS
Peter Egger 1. ?? To doodle = Kritzelei 2003 von CH-Informatiker Michael Naef entwickelt Kostenloses Werkzeug zur Erstellung von Terminumfragen.
Kollektionen in Java Aufzählungstypen, Generische Typen
Interpreter Seminar Entwurfsmuster Tobias Webelsiep
Generalisierung/Spezialisierung Subtypisierung/Vererbung
Konzepte der objektorientierten Programmierung
OOP-Begriffe Abstraktion Modellieren Klasse Objekt Attribute Methoden
Analyse von Ablaufdiagrammen
Kompetenz -, Lern - und Prüfungsbereiche Anforderungsbereiche
NDK Enterprise Technologien Informationen Infrastruktur und Fallstudie Daniel Nydegger Studienleiter Enterprise System Entwicklung.
Context-awareness Andreas Bossard, Matthias Hert.
Paradigmenwechsel in der Unternehmensmodellierung Prof. Dr. Wolfgang Voigt Dipl.-Ing. Päd. Alexander Huwaldt UML Extrakt UML Seminar, Chemnitz
Analyseprodukte numerischer Modelle
Neuerungen in Java 5/6/7. Stefan Bühler für InfoPoint Überblick Java 5 neue Sprachfeatures Erweiterungen Klassenbibliothek Java 6 Erweiterungen.
Implementierung eines RDF Stores
SWT-Übung WS 10/ Zusammenfassung.
Grafische Visualisierung von Softwarestrukturen
VirtualPatt 2000 Interaktives 3D-Schachspiel
Institut Experimentelles Software Engineering Fraunhofer IESE Vorstellung des neuen GI Arbeitskreis: Produktlinientools Isabel John, Fraunhofer IESE
Software Design Patterns
OO Analyse und Entwurf für Anwender XII. Entwurfsmuster Dr. Michael Löwe.
-LABORPRAKTIKUM- SOMMERSEMESTER 2005
Design Pattern1 Motivation Entwurfsmuster Entwurf wiederverwendbarer objektorientierter Software schwer gute Entwürfe entstehen durch Wiederverwen- dung.
Dieser Vortrag wird gesponsort von:
Strategy Pattern Teachlet Autor: Sven Wende Replay durch Stephan Schwake Konzepte objektorientierter Programmiersprachen, SS 2006.
Technische Universität München, Informatik XI Angewandte Informatik / Kooperative Systeme Verteilte Anwendungen: Entwurf Dr. Wolfgang Wörndl
1. Betreuer: Prof. Dr. Jörg Striegnitz 2. Betreuer: Dr. Martin Schindler Kontextsensitive Autocompletion für Klassendiagramme in der UML/P Florian Leppers.
 Präsentation transkript:

GI-FG-2.1.9: AK Frameworks Framework-Dokumentation mit Entwurfsmustern GI-FG-2.1.9-AK "Frameworks" - 2. Workshop an der FH Konstanz, 26./27. September 1996 GI-FG-2.1.9: AK Frameworks Framework-Dokumentation mit Entwurfsmustern Klaus Quibeldey-Cirkel; Georg Odenthal (am Rechner) Universität Siegen, FB 12, Technische Informatik, 57068 Siegen http://www.ti.et-inf.uni-siegen.de/staff/quibeldey/uebermich.html E-mail: quibeldey@ti.et-inf.uni-siegen.de © Klaus Quibeldey-Cirkel, Uni Siegen

Übersicht Begriffe Framework-Dokumentation Diskussion GI-FG-2.1.9-AK "Frameworks" - 2. Workshop an der FH Konstanz, 26./27. September 1996 Übersicht Begriffe “Muster”, “Framework” “Design-Muster” - “Meta-Muster” Framework-Dokumentation à la “HotDraw” sonstwie Diskussion Werkzeugunterstützung Schema zur FW-Dokumentation mit Mustern © Klaus Quibeldey-Cirkel, Uni Siegen

Literatur zum Vortrag & GI-FG-2.1.9-AK "Frameworks" - 2. Workshop an der FH Konstanz, 26./27. September 1996 Literatur zum Vortrag & © Klaus Quibeldey-Cirkel, Uni Siegen

“Muster” in der allgemeinen Literatur in der Software-Technik GI-FG-2.1.9-AK "Frameworks" - 2. Workshop an der FH Konstanz, 26./27. September 1996 Überblick Begriffe Framework-Doku Diskussion “Muster” in der allgemeinen Literatur Vorlage, nach der etwas hergestellt wird beispielhaftes Vorbild regelmäßige, sich wiederholende Struktur in der Software-Technik kontextbezogenes Problem-Lösungs-Paar http://www.ti.et-inf.uni-siegen.de/Diplom/Diplom.html#Hombach http://swt1.informatik.uni-hamburg.de/~riehle/1995/Diplomarbeit.html © Klaus Quibeldey-Cirkel, Uni Siegen

Historie I Musterbücher dokumentieren "Stand der Handwerks-künste". GI-FG-2.1.9-AK "Frameworks" - 2. Workshop an der FH Konstanz, 26./27. September 1996 Historie I Musterbücher in der Antike im Mittelalter im 19. u. 20. Jh. dokumentieren "Stand der Handwerks-künste". & [2, S. 138] © Klaus Quibeldey-Cirkel, Uni Siegen

GI-FG-2.1.9-AK "Frameworks" - 2. Workshop an der FH Konstanz, 26./27. September 1996 Historie II Architektur (1976) Christopher Alexander: “154 Teenager´s Cottage*” & [3, S. 723 ff.] © Klaus Quibeldey-Cirkel, Uni Siegen

Aktualität Software-Technik Konferenzen GI-FG-2.1.9-AK "Frameworks" - 2. Workshop an der FH Konstanz, 26./27. September 1996 Aktualität Software-Technik Erich Gamma et al. (Sachkenntnis im Framework-Kontext!) Hillside Group Siemens AG, sd&m http://st-www.cs.uiuc.edu/users/ patterns/Lists.html Konferenzen PLoP ´94 ..., UP ´97 ... EuroPLoP ´96 ... http://st-www.cs.uiuc.edu/users/ patterns/conferences/ Expertenwissen der Autoren: Erich Gamma: ET++ (Dissertation) Richard Helm: Contracts Ralph E. Johnson: HotDraw John M. Vlissides: InterViews/UniDraw © Klaus Quibeldey-Cirkel, Uni Siegen

“Framework” Halbfabrikat (käuflich) GI-FG-2.1.9-AK "Frameworks" - 2. Workshop an der FH Konstanz, 26./27. September 1996 Überblick Begriffe Framework-Doku Diskussion “Framework” Halbfabrikat (käuflich) Klassenverband (keine Klassenbibliothek) Invertierter Kontrollfluß: “Don´t call us, we call you!” Framework-Definition generische Lösung mit kooperierenden Klassen für verwandte Probleme mit einer vorgegebenen Ablaufstruktur & [4, S. 56] © Klaus Quibeldey-Cirkel, Uni Siegen

*ilities Eigen- schaften guter Frameworks Praxis ... & [2, S. 129] GI-FG-2.1.9-AK "Frameworks" - 2. Workshop an der FH Konstanz, 26./27. September 1996 *ilities Eigen- schaften guter Frameworks Reusability Flexibility Maintainability Praxis ... kaum Orientierungs- wissen durch symmetrische Klassen- Strukturen [2] & [2, S. 129] © Klaus Quibeldey-Cirkel, Uni Siegen

“Design-Muster” (Gamma et al.) GI-FG-2.1.9-AK "Frameworks" - 2. Workshop an der FH Konstanz, 26./27. September 1996 “Design-Muster” (Gamma et al.) dokumentieren Mikro-Architekturen (Mikro-Frameworks bei Wolfgang Pree; Verband aus 3-4 Klassen) & [1, 12] © Klaus Quibeldey-Cirkel, Uni Siegen

“Design -Muster” II GoF-Beschreibungsschema (“Gang of Four”) GI-FG-2.1.9-AK "Frameworks" - 2. Workshop an der FH Konstanz, 26./27. September 1996 Überblick Begriffe Framework-Doku Diskussion “Design -Muster” II GoF-Beschreibungsschema (“Gang of Four”) Mustername und Kategorie Zweck Auch bekannt als Motivation Anwendbarkeit Struktur Teilnehmer Interaktionen Konsequenzen Implementierung Beispielcode Bekannte Anwendungen Verwandte Muster alexandrinische Form: Problem (Kräfte), Kontext, Lösung © Klaus Quibeldey-Cirkel, Uni Siegen

“Strategie-Muster”: MVC GI-FG-2.1.9-AK "Frameworks" - 2. Workshop an der FH Konstanz, 26./27. September 1996 Überblick Begriffe Framework-Doku Diskussion “Strategie-Muster”: MVC bestimmt Makro-Architektur Doku-Fokus: invariante Strukturaspekte hier: Trennung der Belange (David Parnas) und starke Kohäsion vs. lose Kopplung (Herbert A. Simon) Duden-Definition für “Strategie”: “... genauer Plan des eigenen Vorgehens, der dazu dient, ein militärisches, politisches, psychologisches o. ä. Ziel zu erreichen, u. in dem man diejenigen Faktoren, die in die eigene Aktion hineinspielen könnten, von vornherein einzukalkulieren versucht.” [Hervorhebung des Referenten] Software-Kontext: Ein Strategie-Muster legt die Über-alles-Architektur (Makro-Architektur) fest - also das, was über der Zeitachse der Versionierung eines Software-Produkts konstant bleibt (vgl. Architektur-Begriff bei G. Booch). Ursprung in SmallTalk (dort GUI-Framework) & [1, 257] © Klaus Quibeldey-Cirkel, Uni Siegen

“Taktik-Muster”: Beobachter GI-FG-2.1.9-AK "Frameworks" - 2. Workshop an der FH Konstanz, 26./27. September 1996 “Taktik-Muster”: Beobachter bestimmt Mikro-Architektur Doku-Fokus: variante Strukturaspekte hier: Anzahl der von einem Objekt abhängigen Objekte sowie die Art, in der die Objekte aktualisiert werden Duden-Definition für “Taktik”: “... Kunst der Anordnung u. Aufstellung ... auf genauen Überlegungen basierende, von bestimmten Erwägungen bestimmte Art u. Weise des Vorgehens, berechnendes, zweckbestimmtes Verhalten.” [Hervorhebung des Referenten] Software-Kontext: Auf der taktischen Entwurfsebene gibt es im allgemeinen mehrere Alternativen, eine Strategie zu unterstützen. Die Auswirkungen eines Taktik-Musters sind prinzipiell lokalisierbar und begrenzt (Mikro-Architektur, vgl. Mechanismus-Begriff bei G. Booch). & [1, 258] © Klaus Quibeldey-Cirkel, Uni Siegen

MVC & Beobachter & [5, 5] Taktik: flexible Aktualisierung GI-FG-2.1.9-AK "Frameworks" - 2. Workshop an der FH Konstanz, 26./27. September 1996 Überblick Begriffe Framework-Doku Diskussion MVC & Beobachter Taktik: flexible Aktualisierung Strategie: “Trennung der Belange”: starke Kohäsion & lose Kopplung & [5, 5] © Klaus Quibeldey-Cirkel, Uni Siegen

Praxisbeispiel Strategie-Muster: Schnittstellen-Kapselung GI-FG-2.1.9-AK "Frameworks" - 2. Workshop an der FH Konstanz, 26./27. September 1996 Praxisbeispiel Strategie-Muster: Schnittstellen-Kapselung invarianter Strukturaspekt: Protokoll der Schnittstelle Taktik-Muster: Fassade varianter Strukturaspekt: Austauschbarkeit der Kommunikationsstruktur zum Subsystem http://www.ti.et-inf.uni-siegen.de/Diplom/Diplom.html#Odenthal © Klaus Quibeldey-Cirkel, Uni Siegen

“Meta-Muster” (Wolfgang Pree) GI-FG-2.1.9-AK "Frameworks" - 2. Workshop an der FH Konstanz, 26./27. September 1996 “Meta-Muster” (Wolfgang Pree) Framework-Kontext: generisch: Entwurf deskriptiv: Dokumentation präskriptiv: Lernhilfe Doku-Fokus Meta-Beschreibungen der Taktik-Muster (Hot Spots vs. Frozen Spots) Hypertext-Editor für Meta-Muster 2. Buch [4a]: “FrameworkPatterns” © Klaus Quibeldey-Cirkel, Uni Siegen

“Meta-Muster” II Frozen Spots: Templates Hot Spots: Hooks T-Klassen GI-FG-2.1.9-AK "Frameworks" - 2. Workshop an der FH Konstanz, 26./27. September 1996 Überblick Begriffe Framework-Doku Diskussion “Meta-Muster” II Frozen Spots: Templates T-Klassen T()-Operationen Hot Spots: Hooks H-Klassen H()-Operationen hRef-Beziehungen & [4, 161] © Klaus Quibeldey-Cirkel, Uni Siegen

Zwischenbilanz ... Musterbegriff: Problem-Lösungs-Paar GI-FG-2.1.9-AK "Frameworks" - 2. Workshop an der FH Konstanz, 26./27. September 1996 Überblick Begriffe Framework-Doku Diskussion Zwischenbilanz ... Musterbegriff: Problem-Lösungs-Paar Entwurfsmuster: neue “literarische Form” (Textsorte) Musterbuch: literarische Gattung mit Tradition Musterbewegung in der Informatik: Fortsetzung des Wiederverwendungsprinzips auf einer höheren Stufe der Wertschöpfung nicht die einzelne Klasse einer Klassenbibliothek, sondern der abstrahierte Entwurf eines Klassenverbandes wird wiederverwendbar © Klaus Quibeldey-Cirkel, Uni Siegen

... Lehr-, Lern- und Diskussionsvehikel allgemeines Schema GI-FG-2.1.9-AK "Frameworks" - 2. Workshop an der FH Konstanz, 26./27. September 1996 Überblick Begriffe Framework-Doku Diskussion ... Lehr-, Lern- und Diskussionsvehikel Muster dokumentieren Erfahrungswissen. James O. Coplien: “Aggressive Disregard for Originality” Entwurfsmuster sind reproduzierbare Kopien ihrer selbst. Sie manifestieren sich erst nach ungezählten Entwurfszyklen (die Punkte im Sierpinski-Fraktal stehen für die Redesigns). Entwurfsmuster sind “kristallisiertes Wissen” aus einem langen Erfahrungsprozeß. Muster sind sprachbildend: Entwurfsvokabular. allgemeines Schema Problem, (Kräfte), Kontext, Lösung & [2, S. 123] © Klaus Quibeldey-Cirkel, Uni Siegen

... Entwurfsmuster = Entwurfsmethode Muster sind vernetzt: GI-FG-2.1.9-AK "Frameworks" - 2. Workshop an der FH Konstanz, 26./27. September 1996 Überblick Begriffe Framework-Doku Diskussion ... Entwurfsmuster = Entwurfsmethode Muster sind vernetzt: Mustersprachen (Christopher Alexander) Mustersysteme (Frank Buschmann et al.) Entwurfsmuster = Strukturinformation Strategie-Muster Strukturinvarianten Taktik-Muster Strukturvarianten © Klaus Quibeldey-Cirkel, Uni Siegen

... Pro Muster Kontra Muster GI-FG-2.1.9-AK "Frameworks" - 2. Workshop an der FH Konstanz, 26./27. September 1996 Überblick Begriffe Framework-Doku Diskussion ... Pro Muster Wiederverwendung von Sachkenntnis (Erfahrungswissen) Wiedererkennung von Strukturen (Orientierungswissen) effizientes Kommunikations-, Lehr- und Lernvehikel Kontra Muster Validierung nur durch Erfahrung, nicht durch Test keine direkte Code-Wiederverwendung täuschend einfach: Schach-Analogie © Klaus Quibeldey-Cirkel, Uni Siegen

Schach-Analogie (Doug Schmidt) GI-FG-2.1.9-AK "Frameworks" - 2. Workshop an der FH Konstanz, 26./27. September 1996 Überblick Begriffe Framework-Doku Diskussion Schach-Analogie (Doug Schmidt) Grundregeln lernen Figuren, Bewegungen, Brettgeometrie etc. Prinzipien lernen strategischer und taktischer Wert einer Figur, einer Stellung etc. Meister studieren Bewegungs- und Konstellationsmuster verstehen, memorieren, wiederholt anwenden Algorithmen, Datenstrukturen, Sprachen etc. strukturiertes, modulares, objektorientiertes Programmieren Analyse-, Design- und Codierungsmuster verstehen, memorieren, wiederholt anwenden © Klaus Quibeldey-Cirkel, Uni Siegen

GI-FG-2.1.9-AK "Frameworks" - 2. Workshop an der FH Konstanz, 26./27. September 1996 Visuelle Analogie (anläßlich einer GI-Arbeitskreis-Initiative in Berlin im Jahre 1 nach Christos Reichstags-Verhüllung) Entwurfsmuster werden nicht erfunden, sie werden enthüllt. Sie stammen ursprünglich aus der Architektur. Sie verhüllen die Strukturdetails und machen so den Entwurf wiedererkennbar. Ein “verinnerlichtes” Entwurfsmuster (hier Observer) wirkt intuitiv: Die grauen Bereiche und der Kreislauf des Methoden- aufrufs werden intuitiv angewandt: AttachTo() - Action() - Notify() - Update() - GetState(). © Klaus Quibeldey-Cirkel, Uni Siegen

FW-Dokumentation I à la HotDraw [7]: deskriptive Muster GI-FG-2.1.9-AK "Frameworks" - 2. Workshop an der FH Konstanz, 26./27. September 1996 Überblick Begriffe Framework-Doku Diskussion FW-Dokumentation I à la HotDraw [7]: deskriptive Muster gerichteter Graph (vom Allgemeinen zum Besonderen) geordnet nach der Häufigkeit der Anwendung Zielgruppe: FW-Anwender (Nicht-Experten) à la HotDraw [8]: generische Muster abgeleitete Muster begründen Sequenz der Entwurfsentscheidungen Zielgruppe: FW-Entwickler (Experten) HotDraw-Entwickler: Kent Beck; Ward Cunningham © Klaus Quibeldey-Cirkel, Uni Siegen

FW-Dokumentation II Meta-Muster à la Pree [4] GI-FG-2.1.9-AK "Frameworks" - 2. Workshop an der FH Konstanz, 26./27. September 1996 Überblick Begriffe Framework-Doku Diskussion FW-Dokumentation II Meta-Muster à la Pree [4] abstrahieren von Design-Mustern (à la Gamma et al.) sind anwendungsneutral beschreiben Mikro-Frameworks lokalisieren die Variabilitätsaspekte (Hot Spots) © Klaus Quibeldey-Cirkel, Uni Siegen

FW-Dokumentation III Cookbook à la Krasner & Pope [5] GI-FG-2.1.9-AK "Frameworks" - 2. Workshop an der FH Konstanz, 26./27. September 1996 Überblick Begriffe Framework-Doku Diskussion FW-Dokumentation III Cookbook à la Krasner & Pope [5] Contracts à la Helm et al. [6] Motifs à la Lajoie & Keller [9] © Klaus Quibeldey-Cirkel, Uni Siegen

FW-Dokumentation IV Navigationstechniken GI-FG-2.1.9-AK "Frameworks" - 2. Workshop an der FH Konstanz, 26./27. September 1996 Überblick Begriffe Framework-Doku Diskussion FW-Dokumentation IV Navigationstechniken Index und Inhaltsverzeichnisse als Guided Tours Stichwortsuche Volltextsuche Textuelle Verweise (Links) Grafische Verweise (Links) Aufruf von Applikationen http://www.ti.et-inf.uni-siegen.de/Diplom/Diplom.html#Odenthal © Klaus Quibeldey-Cirkel, Uni Siegen

GI-FG-2.1.9-AK "Frameworks" - 2. Workshop an der FH Konstanz, 26./27. September 1996 FW- Doku V Beispiel textuelle und grafische Verweise auf Entwurfsmuster, Klassen, Operationen, Objekt-Szenarien http://www.ti.et-inf.uni-siegen.de/ Diplom/Diplom.html#Odenthal © Klaus Quibeldey-Cirkel, Uni Siegen

Werkzeugunterstützung GI-FG-2.1.9-AK "Frameworks" - 2. Workshop an der FH Konstanz, 26./27. September 1996 Überblick Begriffe Framework-Doku Diskussion Werkzeugunterstützung Hypertext vernetzt Muster (Mustersystem, Mustersprache), hält Zugriff auf latenten Pool an Beispielen, verbirgt technische Detail-Erklärungen, sorgt für Transparenz in der Dokumentation, zuschneidbar auf bestimmte Benutzerprofile. SEU-Infrastruktur mit Musterkomponente objectiF 3.0 (Fa. microTOOL, Berlin) http://www.microTOOL.de/ © Klaus Quibeldey-Cirkel, Uni Siegen

Vorschlag zur FW-Dokumentation mit Entwurfsmustern GI-FG-2.1.9-AK "Frameworks" - 2. Workshop an der FH Konstanz, 26./27. September 1996 Überblick Begriffe Framework-Doku Diskussion Vorschlag zur FW-Dokumentation mit Entwurfsmustern Übersicht Ein Klassendiagramm und evtl. weitere Visualisierungen (z. B. Interaktionsdiagramm), die zur Verdeutlichung geeignet sind. Intention Knappe Beschreibung der wesentlichen Zielsetzung. Der Grund, warum das Muster verwendet wurde, sollte deutlich werden. Motivation Ausführliche Beschreibung der Zusammenhänge. Übersicht über die Komponente. Es kann sinnvoll sein, die “Entwicklungsgeschichte” anhand von Diagrammen und Texten aus der Analysephase (z. B. Bezug zu fachlichen Mustern) und anhand des Vorgehens zur Musterausprägung zu illustrieren. Rollen In Klammern wird hinter die Rolle einer Klasse aus dem Entwurfsmuster die konkrete Klasse der Implementierung geschrieben. Diese Zuordnung ist für den Leser, der das Muster kennt und sich über die spezielle Ausprägung informieren will, sehr wichtig. Eine stichpunktartige Beschreibung der Rolle, die die Klasse in der Musterausprägung einnimmt. Zusammenarbeit Die Interaktion zwischen den Klienten und der Musterausprägung wird beschrieben; evtl. Verweis auf ein Interaktionsdiagramm. Konsequenzen Die Konsequenzen aus der konkreten Implementierung (z. B. Erweiterbarkeit, Vergleich mit anderen Realisierungen). Implementierung (optional) Besonderheiten der Implementierung. © Klaus Quibeldey-Cirkel, Uni Siegen

... Hot Spots, Frozen Spots Rezept Integrierbarkeit GI-FG-2.1.9-AK "Frameworks" - 2. Workshop an der FH Konstanz, 26./27. September 1996 Überblick Begriffe Framework-Doku Diskussion ... Hot Spots, Frozen Spots Für die Dokumentation von Frameworks ist die gesonderte Beschreibung der festgelegten Eigenschaften des Frameworks und der durch den Benutzer anzupassenden bzw. zu erweiternden Komponenten essentiell [4]. Aus dieser Beschreibung sollte eindeutig hervorgehen, welche Flexibilität der Anwender erwarten kann und wo die Grenzen sind. Rezept Der Cookbook–Stil [4, 5, 7, 9] beschreibt den Einsatz eines Frameworks anhand eines schrittweisen, durch Beispiele ergänzten Vorgehens. Diese Beschreibung kann durch eine Ready-to-Use-Umgebung, die die direkte Ausführung und somit ein interaktives Ausprobieren eines Frameworks erlaubt, ergänzt werden. Auch eine vorkonfigurierte Debugger-Sitzung kann zum besseren Verständnis geeignet sein. Ist eine feste Entwicklungs- und Laufzeitumgebung vorhanden, bilden interaktive Hilfen für die Nutzung eines Frameworks (Assistenten/Wizzards) das Optimum an Unterstütztung für den Anwender. Integrierbarkeit Beschreibung der nicht-funktionalen Eigenschaften des Frameworks (beispielsweise Portabilität, Realisierung der Ausnahmebehandlung). So ist eine Einschätzung der Integrierbarkeit in bestehende Umgebungen gegeben. Verwendungen (Known Uses) Hier sollte ein Verweis auf möglichst jede Verwendung des Frameworks stehen. Anhand dieser Einsatzbeispiele kann der Anwender am schnellsten die Eignung überprüfen. Strukturelle Erweiterungen (optional) Vor allem bei In-House–Entwicklungen kann es sinnvoll sein, den Entwurf eines Frameworks eingehend zu beschreiben, um dessen Erweiterbarkeit zu erleichtern. Ein Framework durchläuft mehrere Designzyklen, bis die Hot Spots identifiziert sind und so das richtige Maß an Flexibilität erreicht wurde. Wird es in bisher nicht vorgesehenen Bereichen eingesetzt, kann eine Erweiterung nötig sein. © Klaus Quibeldey-Cirkel, Uni Siegen

Workshop (Plenum & Kleingruppen) GI-FG-2.1.9-AK "Frameworks" - 2. Workshop an der FH Konstanz, 26./27. September 1996 Überblick Begriffe Framework-Doku Diskussion Workshop (Plenum & Kleingruppen) Praxiserfahrung mit FW-Dokumentation Defizite? Praxiserfahrung mit Musterform Wunschliste zur “FW-Dokumentation mit Entwurfsmustern” neue Konzepte? neue Werkzeuge? neues Beschreibungsschema? © Klaus Quibeldey-Cirkel, Uni Siegen