Die Präsentation wird geladen. Bitte warten

Die Präsentation wird geladen. Bitte warten

Entwurfsmuster EDV2 - 05 - Entwurfsmuster.

Ähnliche Präsentationen


Präsentation zum Thema: "Entwurfsmuster EDV2 - 05 - Entwurfsmuster."—  Präsentation transkript:

1 Entwurfsmuster EDV Entwurfsmuster

2 Literatur Erich Gamma, Richard Helm, Ralph Johnson, John Vlissides Entwurfsmuster Addison-Wesley, 1.Auflage 1996 ISBN DM 89,90 EDV Entwurfsmuster

3 Warum Entwurfsmuster? Die Wiederverwendung von objektorientierten Programmen (Klassen) wird oft dadurch verhindert, dass zwar im Wesentlichen die erforderliche Funktion durch eine Klasse realisiert wird, aber bestimmte Details nicht ausreichend realisiert sind.  Die Klasse wird erneut programmiert, wobei nur kleine Änderungen vorgenommen werden. Die Wiederverwendbarkeit der Klasse erhöht sich bei jedem Neuentwurf. Je nach Erfahrung des Programmierers wird nach einer kleineren oder größeren Anzahl von Entwürfen eine Klasse programmiert, die sich ohne wesentliche Änderungen wieder verwenden lässt. Dabei stellt sich heraus, dass bei einem guten Entwurf weniger das konkret gelöste Problem im Vordergrund steht. Vielmehr ist ein allgemeines Prinzip realisiert worden, das sich auf viele konkrete Gegebenheiten anwenden lässt. Dieses allgemeine Prinzip lässt sich als Entwurfsmuster formulieren. In guten Entwurfsmustern stecken also die Erfahrungen guter Programmierer. EDV Entwurfsmuster

4 von anderen entwickelte Programme zu verstehen und nachzunutzen.
Durch die Kenntnis von Entwurfsmustern gelingt es auch weniger erfahrenen Programmierern gut strukturierte und wiederverwendbare Programme selbst zu entwickeln, von anderen entwickelte Programme zu verstehen und nachzunutzen. Entwurfsmuster sind nicht für spezielle Programmiersprachen entwickelt. Sie beschreiben vielmehr allgemeine Programmierprobleme und deren prinzipielle Lösung. Sie lassen sich in allen Sprachen in konkrete Programme umsetzen. Entwurfsmuster helfen dem Programmierer, sein Problem zu verstehen, zu strukturieren und mit Hilfe eines Programmes ggf. unter Verwendung vorhandener Bausteine zu lösen. Die Entwicklung von Entwurfsmustern beeinflusst die Entwickler von Programmiersprachen. EDV Entwurfsmuster

5 Bestandteile von Entwurfsmustern
Mustername Stichwort zur Benennung von Mustern Wichtig für den Austausch mit Kollegen wichtig zum klareren Denken in Entwurfsmuster Problemabschnitt Wann ist das Muster anzuwenden? Welches Problem wird adressiert? Was ist der Kontext? Lösungsabschnitt Aus welchen Elementen besteht die Lösung? Welche Beziehungen bestehen zwischen den Elementen? Wofür sind die Elemente Zuständig? Wie arbeiten die Elemente zusammen? Konsequenzabschnitt Welche Vorteile hat die Anwendung dieses Musters? Welche Nachteile hat die Anwendung dieses Musters? EDV Entwurfsmuster

6 Vererbungsmechanismen
Klassenvererbung: Geschieht durch Ableitungen einer Klasse von einer schon vorhandenen Klasse. Klassen enthalten sowohl die Schnittstellendefinitionen als auch die Implementierung. Klassenvererbung erweitert also die Implementierung der Elternklasse zu einer neuen Implementierung. Erweitert die Funktionalität der Elternklasse durch neue Definitionen. Ersetzt Funktionalitäten der Elternklasse durch Überschreiben. Vorteile: Implementierungen können verändert und überschrieben werden. Nachteile: Implementierung ist offen. Die Vererbung hängt von der Implementierung ab. Es entsteht eine komplizierte Klassenhierarchie. EDV Entwurfsmuster

7 Beispiel public class Punkt { public double getX() ...
public double getY() ... } public class FarbigerPunkt extends Punkt public double getR() ... public double getG() ... public double getB() ... EDV Entwurfsmuster

8 Schnittstellenvererbung (in Java durch Interface)
Geschieht durch Ableitung eines Interfaces von einem schon vorhandenen Interface. Interface enthalten nur die Definition der Schnittstellen. Erweitert die Funktionalität durch neue Definitionen. Das Ersetzen von Schnittstellen ist nicht möglich. Vorteile: Es wird nur die Schnittstelle offen gelegt. Implementierungen können geändert werden, ohne dass die Vererbung beeinflusst wird. Nachteile: Es müssen Schnittstellen (Interface) und Implementierung (Class) getrennt entwickelt werden. EDV Entwurfsmuster

9 Beispiel interface Punkt { public double getX(); public double getY();
} interface Farbe public double getR(); public double getG(); public double getB(); public class FarbigerPunkt implements Punkt, Farbe ... EDV Entwurfsmuster

10 Die Klassenhierarchie bleibt flach und übersichtlich.
Komposition Klassen enthalten Objekte anderer Klassen ohne von ihnen abgeleitet zu sein. Funktionen der enthaltenen Klassen können delegiert werden, d.h. eine Methode eines enthaltenen Objektes wird durch eine ähnliche Methode der neuen Klasse aufgerufen. Vorteile: Die Klassenhierarchie bleibt flach und übersichtlich. EDV Entwurfsmuster

11 Beispiel public class Punkt { public double getX()...
public double getY()... } public class Farbe public double getR()... public double getG()... public double getB()... public class FarbigerPunkt Punkt p; Farbe f; public double getX(){ return p.getX(); } ... EDV Entwurfsmuster

12 Collection-Framework
Set Collection SortedSet List AbstractCollection AbstractSet AbstractList AbstractSequentialList EDV Entwurfsmuster HashSet TreeSet ArrayList LinkedList

13 Regeln Programmiere auf Schnittstellen hin, nicht auf Implementierungen. Ziehe Objektkomposition der Klassenvererbung vor. EDV Entwurfsmuster

14 Beispiel: Liste Liste enthält
private Methoden zur Realisierung der Funktionalitäten mit Kenntnis des internen Aufbaus public Methoden zur Verarbeitung der Liste: hängeElementAn (Element) entferneElement (Element) anzahl() public Methoden zum Zugriff auf die Liste: first() next() last() actualElement() Ähnliche Klassen (HashSet, TreeSet) enthalten ähnliche public Methoden. Liste muss gleichzeitig mehrfach durchsucht werden. EDV Entwurfsmuster

15 Realisierung der Zugriffsmethoden innerhalb eines Iterators.
Zugriffsmethoden sind unabhängig von den Verarbeitungsmethoden. Es ist günstig die beiden Teile extra zu bearbeiten. Realisierung der Zugriffsmethoden innerhalb eines Iterators. Die Klasse, die die Daten speichert enthält eine Methode, die ein Iterator-Objekt erzeugt. Das Iterator-Objekt enthält die Informationen über den Zustand des Zugriffs auf die Liste (actualElement-Zeiger). Es kann mehrfach auf die Liste zugegriffen werden. EDV Entwurfsmuster


Herunterladen ppt "Entwurfsmuster EDV2 - 05 - Entwurfsmuster."

Ähnliche Präsentationen


Google-Anzeigen