<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="de">
	<id>https://wiki-de.moshellshocker.dns64.de/index.php?action=history&amp;feed=atom&amp;title=Dependency-Inversion-Prinzip</id>
	<title>Dependency-Inversion-Prinzip - Versionsgeschichte</title>
	<link rel="self" type="application/atom+xml" href="https://wiki-de.moshellshocker.dns64.de/index.php?action=history&amp;feed=atom&amp;title=Dependency-Inversion-Prinzip"/>
	<link rel="alternate" type="text/html" href="https://wiki-de.moshellshocker.dns64.de/index.php?title=Dependency-Inversion-Prinzip&amp;action=history"/>
	<updated>2026-05-16T22:11:07Z</updated>
	<subtitle>Versionsgeschichte dieser Seite in Wikipedia (Deutsch) – Lokale Kopie</subtitle>
	<generator>MediaWiki 1.43.8</generator>
	<entry>
		<id>https://wiki-de.moshellshocker.dns64.de/index.php?title=Dependency-Inversion-Prinzip&amp;diff=965492&amp;oldid=prev</id>
		<title>imported&gt;A11158: /* Beispiel */</title>
		<link rel="alternate" type="text/html" href="https://wiki-de.moshellshocker.dns64.de/index.php?title=Dependency-Inversion-Prinzip&amp;diff=965492&amp;oldid=prev"/>
		<updated>2025-05-28T08:07:24Z</updated>

		<summary type="html">&lt;p&gt;&lt;span class=&quot;autocomment&quot;&gt;Beispiel&lt;/span&gt;&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Neue Seite&lt;/b&gt;&lt;/p&gt;&lt;div&gt;[[Datei:DIP abhaengigkeit.png|mini|Strukturierung von Modulen nach DIP]]&lt;br /&gt;
&lt;br /&gt;
Das &amp;#039;&amp;#039;&amp;#039;Dependency Inversion Principle&amp;#039;&amp;#039;&amp;#039; (&amp;#039;&amp;#039;&amp;#039;DIP&amp;#039;&amp;#039;&amp;#039;, {{enS}} für &amp;#039;&amp;#039;&amp;#039;Abhängigkeits-Umkehr-Prinzip&amp;#039;&amp;#039;&amp;#039;) ist ein Prinzip beim [[Objektorientiertes Design|objektorientierten Entwurf]] von [[Software]]. Es beschäftigt sich mit der Abhängigkeit von [[Modul (Software)|Modul]]en.&lt;br /&gt;
&lt;br /&gt;
Im Allgemeinen wird das DIP beschrieben durch:&lt;br /&gt;
: &amp;#039;&amp;#039;Module höherer Ebenen sollten nicht von Modulen niedrigerer Ebenen abhängen.&amp;lt;br /&amp;gt;Beide sollten von Abstraktionen abhängen.&amp;#039;&amp;#039;&lt;br /&gt;
: &amp;#039;&amp;#039;Abstraktionen sollten nicht von Details abhängen.&amp;lt;br /&amp;gt;Details sollten von Abstraktionen abhängen.&amp;#039;&amp;#039;&lt;br /&gt;
&lt;br /&gt;
== Problemstellung und Lösung ==&lt;br /&gt;
[[Objektorientiertes Design|Objektorientierte Entwürfe]] werden in [[Modul (Software)|Module]] strukturiert, die unterschiedliche Verantwortlichkeiten umsetzen. Eine gängige Praxis ist das Anordnen der Module in Ebenen. Je niedriger die Ebene eines Moduls, desto spezieller sind die Vorgänge, die es definiert. In Modulen niedrigerer Ebenen werden Abläufe definiert, welche von allgemeineren Abläufen in höheren Ebenen benutzt werden.&lt;br /&gt;
&lt;br /&gt;
Falls diese Anordnung falsch umgesetzt wird, also Module höherer Ebenen von Modulen niedrigerer Ebenen abhängen, entsteht ein Problem. Änderungen in Modulen niedrigerer Ebenen führen unweigerlich zu Änderungen in Modulen höherer Ebenen. Dies widerspricht aber einerseits dem eigentlichen Ansatz der Hierarchie, andererseits führt es zu zyklischen Abhängigkeiten. Dadurch kommt es zu einer erhöhten [[Kopplung (Softwareentwicklung)|Kopplung]] der Module, welche Änderungen in Architektur und Design unnötig verkomplizieren.&lt;br /&gt;
&lt;br /&gt;
Der Lösungsansatz ist die Invertierung der Abhängigkeit. Das Modul der höheren Ebene definiert die Schnittstelle, mit der es arbeitet. Module niedrigerer Ebene realisieren die Schnittstelle.&lt;br /&gt;
&lt;br /&gt;
== Beispiel ==&lt;br /&gt;
Wir betrachten ein einfaches Schalter-Lampe-Modell. Das Drücken des Schalters soll die Lampe an- oder ausschalten.&lt;br /&gt;
&lt;br /&gt;
Eine einfache Implementierung in [[Java (Programmiersprache)|Java]]:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
public class Lampe {&lt;br /&gt;
   private boolean leuchtet;&lt;br /&gt;
&lt;br /&gt;
   public void anschalten() {&lt;br /&gt;
      leuchtet = true;&lt;br /&gt;
   }&lt;br /&gt;
&lt;br /&gt;
   public void ausschalten() {&lt;br /&gt;
      leuchtet = false;&lt;br /&gt;
   }&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
public class Schalter {&lt;br /&gt;
   private Lampe lampe;&lt;br /&gt;
   private boolean gedrueckt;&lt;br /&gt;
&lt;br /&gt;
   public Schalter(Lampe lampe) {&lt;br /&gt;
      this.lampe = lampe;&lt;br /&gt;
   }&lt;br /&gt;
&lt;br /&gt;
   public void drueckeSchalter() {&lt;br /&gt;
      gedrueckt = !gedrueckt;&lt;br /&gt;
      if(gedrueckt) {&lt;br /&gt;
         lampe.anschalten();&lt;br /&gt;
      } else {&lt;br /&gt;
         lampe.ausschalten();&lt;br /&gt;
      }&lt;br /&gt;
   }&lt;br /&gt;
}&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Schalter steuert den Ablauf des Verhaltens und benutzt dazu Lampe. Demnach sollte es einem Modul höherer Ebene angehören. Jedoch verletzt das beschriebene Modell das DIP, da Schalter abhängig von Lampe ist. Wird entschieden, dass die Methoden von Lampe umbenannt werden, muss auch Schalter geändert werden.&lt;br /&gt;
&lt;br /&gt;
Das grundlegende Problem ist, dass Schalter direkt mit Lampe arbeitet, welches zu einem niedrigeren Modul gehört. Schalter sollte selbst definieren, wie das Objekt aussehen sollte, mit dem es arbeitet.&lt;br /&gt;
&lt;br /&gt;
Die Lösung in Java:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
public interface Geraet{&lt;br /&gt;
   public void anschalten();&lt;br /&gt;
   public void ausschalten();&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
public class Lampe implements Geraet{&lt;br /&gt;
   private boolean leuchtet = false;&lt;br /&gt;
&lt;br /&gt;
   public void anschalten() {&lt;br /&gt;
      leuchtet = true;&lt;br /&gt;
   }&lt;br /&gt;
&lt;br /&gt;
   public void ausschalten() {&lt;br /&gt;
      leuchtet = false;&lt;br /&gt;
   }&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
public class Schalter {&lt;br /&gt;
   private Geraet lampe;&lt;br /&gt;
   private boolean gedrueckt;&lt;br /&gt;
&lt;br /&gt;
   public Schalter(Geraet lampe) {&lt;br /&gt;
      this.lampe= lampe;&lt;br /&gt;
   }&lt;br /&gt;
&lt;br /&gt;
   public void drueckeSchalter() {&lt;br /&gt;
      gedrueckt = !gedrueckt;&lt;br /&gt;
      if(gedrueckt) {&lt;br /&gt;
         this.lampe.anschalten();&lt;br /&gt;
      } else {&lt;br /&gt;
         this.lampe.ausschalten();&lt;br /&gt;
      }&lt;br /&gt;
   }&lt;br /&gt;
}&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
== Siehe auch ==&lt;br /&gt;
&lt;br /&gt;
* [[Service Provider Interface]]&lt;br /&gt;
* [[Plug-in]]&lt;br /&gt;
* [[Inversion of Control]]&lt;br /&gt;
&lt;br /&gt;
== Literatur ==&lt;br /&gt;
* {{Literatur |Autor=Robert C. Martin |Titel=The Dependency Inversion Principle |Datum=1996-05 |Online={{Webarchiv |url=http://www.objectmentor.com/resources/articles/dip.pdf |wayback=20110714224327 |text=PDF}}}}&lt;br /&gt;
&lt;br /&gt;
{{Navigationsleiste Prinzipien objektorientierten Designs}}&lt;br /&gt;
&lt;br /&gt;
[[Kategorie:Objektorientierte Programmierung]]&lt;/div&gt;</summary>
		<author><name>imported&gt;A11158</name></author>
	</entry>
</feed>