|
| 1 | +--- |
| 2 | +title: "Abstract Document Pattern in Java: Vereinfachung der Datenverwaltung mit Flexibilität" |
| 3 | +shortTitle: Abstract Document |
| 4 | +description: "Erkunden Sie das Abstract Document Design Pattern in Java. Lernen Sie seine Absicht, Erklärung, Anwendbarkeit, Vorteile kennen und sehen Sie reale Beispiele zur Implementierung flexibler und dynamischer Datenstrukturen." |
| 5 | +category: Strukturell |
| 6 | +language: de |
| 7 | +tag: |
| 8 | + - Abstraktion |
| 9 | + - Entkopplung |
| 10 | + - Dynamische Typisierung |
| 11 | + - Kapselung |
| 12 | + - Erweiterbarkeit |
| 13 | + - Polymorphismus |
| 14 | +--- |
| 15 | + |
| 16 | +## Absicht des Abstract Document Design Patterns |
| 17 | + |
| 18 | +Das Abstract Document Design Pattern in Java ist ein wichtiges strukturelles Design Pattern, das eine konsistente Möglichkeit bietet, hierarchische und baumartige Datenstrukturen zu handhaben, indem es eine gemeinsame Schnittstelle für verschiedene Dokumenttypen definiert. Es trennt die Kernstruktur des Dokuments von spezifischen Datenformaten und ermöglicht dynamische Aktualisierungen und vereinfachte Wartung. |
| 19 | + |
| 20 | +## Detaillierte Erklärung des Abstract Document Patterns mit realen Beispielen |
| 21 | + |
| 22 | +Das Abstract Document Design Pattern in Java ermöglicht die dynamische Handhabung nicht-statischer Eigenschaften. Dieses Pattern verwendet das Konzept der Traits, um Typsicherheit zu gewährleisten und Eigenschaften verschiedener Klassen in eine Menge von Schnittstellen zu trennen. |
| 23 | + |
| 24 | +Reales Beispiel |
| 25 | + |
| 26 | +> Betrachten Sie ein Bibliothekssystem, das das Abstract Document Design Pattern in Java implementiert, wo Bücher verschiedene Formate und Attribute haben können: physische Bücher, eBooks und Hörbücher. Jedes Format hat einzigartige Eigenschaften, wie Seitenzahl für physische Bücher, Dateigröße für eBooks und Dauer für Hörbücher. Das Abstract Document Design Pattern ermöglicht es dem Bibliothekssystem, diese verschiedenen Formate flexibel zu verwalten. Durch die Verwendung dieses Patterns kann das System Eigenschaften dynamisch speichern und abrufen, ohne dass eine starre Struktur für jeden Buchtyp erforderlich ist, was es einfacher macht, neue Formate oder Attribute in der Zukunft hinzuzufügen, ohne dass wesentliche Änderungen am Codebase erforderlich sind. |
| 27 | +
|
| 28 | +In einfachen Worten |
| 29 | + |
| 30 | +> Das Abstract Document Pattern ermöglicht das Anhängen von Eigenschaften an Objekte, ohne dass diese davon wissen. |
| 31 | +
|
| 32 | +Wikipedia sagt |
| 33 | + |
| 34 | +> Ein objektorientiertes strukturelles Design Pattern zur Organisation von Objekten in schwach typisierten Schlüssel-Wert-Speichern und zur Bereitstellung der Daten über typisierte Ansichten. Der Zweck des Patterns besteht darin, einen hohen Grad an Flexibilität zwischen Komponenten in einer stark typisierten Sprache zu erreichen, in der neue Eigenschaften zur Objektstruktur dynamisch hinzugefügt werden können, ohne die Unterstützung der Typsicherheit zu verlieren. Das Pattern verwendet Traits, um verschiedene Eigenschaften einer Klasse in verschiedene Schnittstellen zu trennen. |
| 35 | +
|
| 36 | +## Programmatisches Beispiel des Abstract Document Patterns in Java |
| 37 | + |
| 38 | +Betrachten Sie ein Auto, das aus mehreren Teilen besteht. Wir wissen jedoch nicht, ob das spezifische Auto wirklich alle Teile hat oder nur einige davon. Unsere Autos sind dynamisch und extrem flexibel. |
| 39 | + |
| 40 | +Lassen Sie uns zunächst die Basisklassen `Document` und `AbstractDocument` definieren. Sie sorgen im Wesentlichen dafür, dass das Objekt eine Eigenschaftsmap und eine beliebige Anzahl von Kindobjekten enthält. |
| 41 | + |
| 42 | +```java |
| 43 | +public interface Document { |
| 44 | + |
| 45 | + Void put(String key, Object value); |
| 46 | + |
| 47 | + Object get(String key); |
| 48 | + |
| 49 | + <T> Stream<T> children(String key, Function<Map<String, Object>, T> constructor); |
| 50 | +} |
| 51 | + |
| 52 | +public abstract class AbstractDocument implements Document { |
| 53 | + |
| 54 | + private final Map<String, Object> properties; |
| 55 | + |
| 56 | + protected AbstractDocument(Map<String, Object> properties) { |
| 57 | + Objects.requireNonNull(properties, "properties map is required"); |
| 58 | + this.properties = properties; |
| 59 | + } |
| 60 | + |
| 61 | + @Override |
| 62 | + public Void put(String key, Object value) { |
| 63 | + properties.put(key, value); |
| 64 | + return null; |
| 65 | + } |
| 66 | + |
| 67 | + @Override |
| 68 | + public Object get(String key) { |
| 69 | + return properties.get(key); |
| 70 | + } |
| 71 | + |
| 72 | + @Override |
| 73 | + public <T> Stream<T> children(String key, Function<Map<String, Object>, T> constructor) { |
| 74 | + return Stream.ofNullable(get(key)) |
| 75 | + .filter(Objects::nonNull) |
| 76 | + .map(el -> (List<Map<String, Object>>) el) |
| 77 | + .findAny() |
| 78 | + .stream() |
| 79 | + .flatMap(Collection::stream) |
| 80 | + .map(constructor); |
| 81 | + } |
| 82 | + |
| 83 | + // Andere Eigenschaften und Methoden... |
| 84 | +} |
| 85 | +``` |
| 86 | +Als nächstes definieren wir ein Enum Property und eine Menge von Schnittstellen für Typ, Preis, Modell und Teile. Dies ermöglicht es uns, eine statisch aussehende Schnittstelle für unsere Car-Klasse zu erstellen. |
| 87 | + |
| 88 | +```java |
| 89 | +public enum Property { |
| 90 | + |
| 91 | + PARTS, TYPE, PRICE, MODEL |
| 92 | +} |
| 93 | + |
| 94 | +public interface HasType extends Document { |
| 95 | + |
| 96 | + default Optional<String> getType() { |
| 97 | + return Optional.ofNullable((String) get(Property.TYPE.toString())); |
| 98 | + } |
| 99 | +} |
| 100 | + |
| 101 | +public interface HasPrice extends Document { |
| 102 | + |
| 103 | + default Optional<Number> getPrice() { |
| 104 | + return Optional.ofNullable((Number) get(Property.PRICE.toString())); |
| 105 | + } |
| 106 | +} |
| 107 | + |
| 108 | +public interface HasModel extends Document { |
| 109 | + |
| 110 | + default Optional<String> getModel() { |
| 111 | + return Optional.ofNullable((String) get(Property.MODEL.toString())); |
| 112 | + } |
| 113 | +} |
| 114 | + |
| 115 | +public interface HasParts extends Document { |
| 116 | + |
| 117 | + default Stream<Part> getParts() { |
| 118 | + return children(Property.PARTS.toString(), Part::new); |
| 119 | + } |
| 120 | +} |
| 121 | +``` |
| 122 | + |
| 123 | +Jetzt sind wir bereit, das `Car` einzuführen. |
| 124 | + |
| 125 | +```java |
| 126 | + public static void main(String[] args) { |
| 127 | + LOGGER.info("Konstruktion von Teilen und Auto"); |
| 128 | + |
| 129 | + var wheelProperties = Map.of( |
| 130 | + Property.TYPE.toString(), "wheel", |
| 131 | + Property.MODEL.toString(), "15C", |
| 132 | + Property.PRICE.toString(), 100L); |
| 133 | + |
| 134 | + var doorProperties = Map.of( |
| 135 | + Property.TYPE.toString(), "door", |
| 136 | + Property.MODEL.toString(), "Lambo", |
| 137 | + Property.PRICE.toString(), 300L); |
| 138 | + |
| 139 | + var carProperties = Map.of( |
| 140 | + Property.MODEL.toString(), "300SL", |
| 141 | + Property.PRICE.toString(), 10000L, |
| 142 | + Property.PARTS.toString(), List.of(wheelProperties, doorProperties)); |
| 143 | + |
| 144 | + var car = new Car(carProperties); |
| 145 | + |
| 146 | + LOGGER.info("Hier ist unser Auto:"); |
| 147 | + LOGGER.info("-> Modell: {}", car.getModel().orElseThrow()); |
| 148 | + LOGGER.info("-> Preis: {}", car.getPrice().orElseThrow()); |
| 149 | + LOGGER.info("-> Teile: "); |
| 150 | + car.getParts().forEach(p -> LOGGER.info("\t{}/{}/{}", |
| 151 | + p.getType().orElse(null), |
| 152 | + p.getModel().orElse(null), |
| 153 | + p.getPrice().orElse(null)) |
| 154 | + ); |
| 155 | +} |
| 156 | +``` |
| 157 | +Die Programmausgabe: |
| 158 | + |
| 159 | +``` |
| 160 | +07:21:57.391 [main] INFO com.iluwatar.abstractdocument.App -- Konstruktion von Teilen und Auto |
| 161 | +07:21:57.393 [main] INFO com.iluwatar.abstractdocument.App -- Hier ist unser Auto: |
| 162 | +07:21:57.393 [main] INFO com.iluwatar.abstractdocument.App -- -> Modell: 300SL |
| 163 | +07:21:57.394 [main] INFO com.iluwatar.abstractdocument.App -- -> Preis: 10000 |
| 164 | +07:21:57.394 [main] INFO com.iluwatar.abstractdocument.App -- -> Teile: |
| 165 | +07:21:57.395 [main] INFO com.iluwatar.abstractdocument.App -- Rad/15C/100 |
| 166 | +07:21:57.395 [main] INFO com.iluwatar.abstractdocument.App -- Tür/Lambo/300 |
| 167 | +``` |
| 168 | +## Abstract Document Pattern Klassendiagramm |
| 169 | + |
| 170 | + |
| 171 | + |
| 172 | +## Wann sollte das Abstract Document Pattern in Java verwendet werden? |
| 173 | + |
| 174 | +Das Abstract Document Design Pattern ist besonders vorteilhaft in Szenarien, die eine Verwaltung unterschiedlicher Dokumenttypen in Java erfordern, die einige gemeinsame Attribute oder Verhaltensweisen teilen, aber auch einzigartige Attribute oder Verhaltensweisen haben, die spezifisch für ihren Typ sind. Hier sind einige Szenarien, in denen das Abstract Document Design Pattern anwendbar ist: |
| 175 | + |
| 176 | +* **Content-Management-Systeme (CMS)**: In einem CMS könnten verschiedene Arten von Inhalten wie Artikel, Bilder, Videos usw. vorkommen. Jede Inhaltsart könnte gemeinsame Attribute wie Erstellungsdatum, Autor und Tags haben, aber auch spezifische Attribute wie Bildabmessungen für Bilder oder Videodauer für Videos. |
| 177 | + |
| 178 | +* **Dateisysteme**: Wenn Sie ein Dateisystem entwerfen, in dem unterschiedliche Dateitypen verwaltet werden müssen, wie Dokumente, Bilder, Audiodateien und Verzeichnisse, kann das Abstract Document Pattern helfen, eine konsistente Möglichkeit zum Zugriff auf Attribute wie Dateigröße, Erstellungsdatum usw. zu bieten, während spezifische Attribute wie Bildauflösung oder Audiodauer berücksichtigt werden. |
| 179 | + |
| 180 | +* **E-Commerce-Systeme**: Eine E-Commerce-Plattform könnte verschiedene Produkttypen haben, wie physische Produkte, digitale Downloads und Abonnements. Jeder Typ könnte gemeinsame Attribute wie Name, Preis und Beschreibung haben, aber auch einzigartige Attribute wie Versandgewicht für physische Produkte oder Download-Link für digitale Produkte. |
| 181 | + |
| 182 | +* **Medizinische Aufzeichnungssysteme**: Im Gesundheitswesen könnten Patientenakten verschiedene Datentypen enthalten, wie demografische Daten, medizinische Vorgeschichte, Testergebnisse und Rezepte. Das Abstract Document Pattern kann helfen, gemeinsame Attribute wie Patienten-ID und Geburtsdatum zu verwalten, während spezialisierte Attribute wie Testergebnisse oder verschriebene Medikamente berücksichtigt werden. |
| 183 | + |
| 184 | +* **Konfigurationsmanagement**: Bei der Verwaltung von Konfigurationseinstellungen für Softwareanwendungen gibt es möglicherweise verschiedene Arten von Konfigurationselementen, jedes mit einer eigenen Reihe von Attributen. Das Abstract Document Pattern kann verwendet werden, um diese Konfigurationselemente zu verwalten, während eine konsistente Möglichkeit zum Zugriff auf und Bearbeiten der Attribute sichergestellt wird. |
| 185 | + |
| 186 | +* **Bildungsplattformen**: Bildungssysteme könnten verschiedene Arten von Lernmaterialien wie textbasierte Inhalte, Videos, Quizze und Aufgaben haben. Gemeinsame Attribute wie Titel, Autor und Veröffentlichungsdatum können geteilt werden, während spezifische Attribute wie Videodauer oder Aufgabenfälligkeit für jeden Typ einzigartig sind. |
| 187 | + |
| 188 | +* **Projektmanagement-Tools**: In Projektmanagement-Anwendungen könnten unterschiedliche Aufgabenarten wie To-Do-Items, Meilensteine und Probleme vorliegen. Das Abstract Document Pattern könnte verwendet werden, um allgemeine Attribute wie Aufgabenname und Zuweisung zu handhaben, während spezifische Attribute wie Meilensteindaten oder Problemprioritäten zugelassen werden. |
| 189 | + |
| 190 | +* **Dokumente haben vielfältige und sich entwickelnde Attributstrukturen.** |
| 191 | + |
| 192 | +* **Dynamisches Hinzufügen neuer Eigenschaften ist eine häufige Anforderung.** |
| 193 | + |
| 194 | +* **Entkopplung des Datenzugriffs von spezifischen Formaten ist entscheidend.** |
| 195 | + |
| 196 | +* **Wartbarkeit und Flexibilität sind entscheidend für die Codebasis.** |
| 197 | + |
| 198 | +Die Hauptidee hinter dem Abstract Document Design Pattern ist es, eine flexible und erweiterbare Möglichkeit zur Verwaltung unterschiedlicher Dokumenttypen oder Entitäten mit gemeinsamen und spezifischen Attributen bereitzustellen. Durch die Definition einer gemeinsamen Schnittstelle und deren Implementierung über verschiedene Dokumenttypen hinweg können Sie einen besser organisierten und konsistenteren Ansatz zur Handhabung komplexer Datenstrukturen erreichen. |
| 199 | + |
| 200 | +## Vorteile und Abwägungen des Abstract Document Patterns |
| 201 | + |
| 202 | +**Vorteile:** |
| 203 | + |
| 204 | +* **Flexibilität**: Ermöglicht die Handhabung unterschiedlicher Dokumentstrukturen und -eigenschaften. |
| 205 | +* **Erweiterbarkeit**: Neue Attribute können dynamisch hinzugefügt werden, ohne bestehenden Code zu brechen. |
| 206 | +* **Wartbarkeit**: Fördert sauberen und anpassungsfähigen Code durch Trennung der Verantwortlichkeiten. |
| 207 | +* **Wiederverwendbarkeit**: Typspezifische Ansichten ermöglichen eine Wiederverwendung des Codes zum Zugriff auf bestimmte Attributtypen. |
| 208 | + |
| 209 | +**Abwägungen:** |
| 210 | + |
| 211 | +* **Komplexität**: Erfordert die Definition von Schnittstellen und Ansichten, was zu zusätzlichem Implementierungsaufwand führt. |
| 212 | +* **Leistung**: Kann im Vergleich zum direkten Datenzugriff zu leichtem Leistungsaufwand führen. |
| 213 | + |
| 214 | +## Quellen und Danksagungen |
| 215 | + |
| 216 | +* [Design Patterns: Elements of Reusable Object-Oriented Software](https://amzn.to/3w0pvKI) |
| 217 | +* [Java Design Patterns: A Hands-On Experience with Real-World Examples](https://amzn.to/3yhh525) |
| 218 | +* [Pattern-Oriented Software Architecture Volume 4: A Pattern Language for Distributed Computing (v. 4)](https://amzn.to/49zRP4R) |
| 219 | +* [Patterns of Enterprise Application Architecture](https://amzn.to/3WfKBPR) |
| 220 | +* [Abstract Document Pattern (Wikipedia)](https://en.wikipedia.org/wiki/Abstract_Document_Pattern) |
| 221 | +* [Dealing with Properties (Martin Fowler)](http://martinfowler.com/apsupp/properties.pdf) |
| 222 | + |
| 223 | + |
| 224 | + |
| 225 | + |
| 226 | + |
0 commit comments