<?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=Kreis-Ellipse-Problem</id>
	<title>Kreis-Ellipse-Problem - 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=Kreis-Ellipse-Problem"/>
	<link rel="alternate" type="text/html" href="https://wiki-de.moshellshocker.dns64.de/index.php?title=Kreis-Ellipse-Problem&amp;action=history"/>
	<updated>2026-05-31T09:26:35Z</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=Kreis-Ellipse-Problem&amp;diff=1625376&amp;oldid=prev</id>
		<title>imported&gt;AX29: Änderungen von ~2025-27300-56 (Diskussion) auf die letzte Version von Cactus26 zurückgesetzt</title>
		<link rel="alternate" type="text/html" href="https://wiki-de.moshellshocker.dns64.de/index.php?title=Kreis-Ellipse-Problem&amp;diff=1625376&amp;oldid=prev"/>
		<updated>2025-10-01T09:04:27Z</updated>

		<summary type="html">&lt;p&gt;Änderungen von &lt;a href=&quot;/index.php/Spezial:Beitr%C3%A4ge/~2025-27300-56&quot; title=&quot;Spezial:Beiträge/~2025-27300-56&quot;&gt;~2025-27300-56&lt;/a&gt; (&lt;a href=&quot;/index.php?title=Benutzer_Diskussion:~2025-27300-56&amp;amp;action=edit&amp;amp;redlink=1&quot; class=&quot;new&quot; title=&quot;Benutzer Diskussion:~2025-27300-56 (Seite nicht vorhanden)&quot;&gt;Diskussion&lt;/a&gt;) auf die letzte Version von &lt;a href=&quot;/index.php?title=Benutzer:Cactus26&amp;amp;action=edit&amp;amp;redlink=1&quot; class=&quot;new&quot; title=&quot;Benutzer:Cactus26 (Seite nicht vorhanden)&quot;&gt;Cactus26&lt;/a&gt; zurückgesetzt&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Neue Seite&lt;/b&gt;&lt;/p&gt;&lt;div&gt;Das &amp;#039;&amp;#039;&amp;#039;Kreis-Ellipse-Problem&amp;#039;&amp;#039;&amp;#039; ist ein prominentes, wiederholt diskutiertes Problem aus dem Bereich der [[Objektorientierte Programmierung|objektorientierten Programmierung]] im Zusammenhang mit der [[Objektmodell|Modellierung]] von [[Vererbung (Programmierung)|Vererbungsbeziehungen]]. Einerseits &amp;#039;&amp;#039;ist ein&amp;#039;&amp;#039; [[Kreis]] eindeutig eine [[Ellipse]], was dafür spricht, dass es sich um einen [[Subtyp]] der Ellipse handelt. Andererseits führt die Unterstützung einer nachträglichen, unabhängigen Veränderung der Länge der beiden [[Große Halbachse|Halbachsen]], die für eine Ellipse sinnvoll sein kann, bei einem Kreis zu einem Problem, das häufig im Zusammenhang mit dem [[Liskovsches Substitutionsprinzip|Liskovschen Substitutionsprinzip]] diskutiert wird.&lt;br /&gt;
&lt;br /&gt;
Ein analoger Fall ist die Beziehung zwischen [[Quadrat]] und [[Rechteck]].&lt;br /&gt;
&lt;br /&gt;
== Beispiel ==&lt;br /&gt;
In einer typischen Klassenhierarchie zur Implementierung einer [[Grafiksoftware]] könnte von einer [[Basisklasse]] &amp;lt;code&amp;gt;GrafischesElement&amp;lt;/code&amp;gt; –&amp;amp;nbsp;neben anderen Unterklassen&amp;amp;nbsp;– die Klasse &amp;lt;code&amp;gt;Ellipse&amp;lt;/code&amp;gt; abgeleitet werden und von dieser wiederum die Klasse &amp;lt;code&amp;gt;Kreis&amp;lt;/code&amp;gt;. Bereits in der Basisklasse gibt es eine [[Methode (Programmierung)|Methode]] &amp;lt;code&amp;gt;Zeichne&amp;lt;/code&amp;gt;, die das jeweilige Grafikelement auf den Bildschirm darstellt. Nun ist durchaus denkbar, dass die Methoden &amp;lt;code&amp;gt;SkaliereX&amp;lt;/code&amp;gt; und &amp;lt;code&amp;gt;SkaliereY&amp;lt;/code&amp;gt; in der Klasse &amp;lt;code&amp;gt;Ellipse&amp;lt;/code&amp;gt; eingeführt werden, um dem Benutzer die nachträgliche Anpassung der Halbachsen zu ermöglichen. &amp;lt;code&amp;gt;Kreis&amp;lt;/code&amp;gt; als Spezialisierung der Ellipse erbt diese Methoden. Allerdings ist ein Kreis nach Anpassung nur einer der beiden Halbachsen kein Kreis mehr. Ein möglicher Ausweg aus diesem Dilemma wäre, bei einem Kreis bei Anpassung einer der Halbachsen die andere automatisch anzugleichen. Allerdings wäre dies ein Verstoß gegen das [[liskovsches Substitutionsprinzip|liskovsche Substitutionsprinzip]], da ein Objekt der Klasse &amp;lt;code&amp;gt;Kreis&amp;lt;/code&amp;gt; sich nicht mehr verhält, wie man es für eine &amp;lt;code&amp;gt;Ellipse&amp;lt;/code&amp;gt; erwarten würde.&lt;br /&gt;
&lt;br /&gt;
== Lösungsvorschläge ==&lt;br /&gt;
Hauptsächlich werden folgende Lösungsmöglichkeiten dieses Problems diskutiert:&lt;br /&gt;
&lt;br /&gt;
*&amp;#039;&amp;#039;Fehlschlagspezifikation für die Größenanpassung&amp;#039;&amp;#039;: Bereits auf Ebene der Ellipse wird vorgesehen, dass beim Methodenaufruf zur Änderung der Größe ein Scheitern der Operation möglich ist, was beispielsweise mittels eines Rückgabewerts kenntlich gemacht wird. Das Problem dieser und ähnlicher Abhilfemaßnahmen ist vor allem, dass eine solche Vorkehrung bereits auf Ebene der Basisklasse eingeführt werden muss, wo sie eigentlich unnötig ist. Verallgemeinert gesehen erfordert diese Lösungsvariante, dass die Entwickler der Basisklasse diesen Fall vorausahnen müssen, obwohl sie den konkreten Problemfall möglicherweise gar nicht kennen, da typischerweise Entwickler einer Basisklasse weder alle Anwendungsfälle ihrer Klasse kennen, noch mit den Entwicklern der spezialisierenden Klassen in Kontakt stehen.&lt;br /&gt;
&lt;br /&gt;
*&amp;#039;&amp;#039;Vertauschen der Vererbungsrichtung&amp;#039;&amp;#039;: Diese Variante wurde in einer frühen, von [[Adele Goldberg]] entwickelten, [[Klassenbibliothek]] vom Prinzip her umgesetzt, und zwar war dort ein Rechteck als Spezialisierung eines Quadrats implementiert. Die Argumentation war, dass ein Rechteck zu einem Quadrat eine neue Eigenschaft ergänzt und zwar die Länge der anderen Seite. Kritisiert wird an dieser Implementierung, dass die Aussage „ein Rechteck ist ein Quadrat“ mathematisch widersinnig sei.&amp;lt;ref name=&amp;quot;Meyer1996&amp;quot;&amp;gt;B. Meyer: &amp;#039;&amp;#039;The many faces of inheritance: A taxonomy of taxonomy&amp;#039;&amp;#039;. In: IEEE Computer, Vol. 29, Seite 105–108, 1996.&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
*&amp;#039;&amp;#039;Verzicht auf eine Spezialisierung&amp;#039;&amp;#039; für &amp;lt;code&amp;gt;Kreis&amp;lt;/code&amp;gt;: Stattdessen kann in &amp;lt;code&amp;gt;Ellipse&amp;lt;/code&amp;gt; eine zusätzliche Methode &amp;lt;code&amp;gt;IstKreis&amp;lt;/code&amp;gt; vorgesehen werden. Der Nachteil dieser Variante ist, dass die Eigenschaften eines Kreises, die spezifisch für diesen sind und für eine Ellipse nicht gelten (beispielsweise der Radius), nicht in der [[Schnittstelle (Objektorientierung)|Schnittstelle]] der Klasse untergebracht werden können. Der Vorteil ist, dass Ellipsen, die über eine nachträgliche Skalierung zu Kreisen werden, gleichberechtigt zu Kreisen sind, die seit Konstruktion solche sind.&lt;br /&gt;
&lt;br /&gt;
*&amp;#039;&amp;#039;Verzicht auf eine Vererbungsbeziehung&amp;#039;&amp;#039;: Keine der beiden Klassen erbt von der anderen, sondern beide erben gleichberechtigt von einer gemeinsamen Basisklasse. Wenn als gemeinsame Basisklasse eine allgemeine Klasse &amp;lt;code&amp;gt;GrafischesElement&amp;lt;/code&amp;gt; verwendet wird, hat das den Nachteil, dass gemeinsame Funktionalität von &amp;lt;code&amp;gt;Kreis&amp;lt;/code&amp;gt; und &amp;lt;code&amp;gt;Ellipse&amp;lt;/code&amp;gt; doppelt implementiert werden muss, das heißt, [[Redundanz (Informationstheorie)|redundant]] ist. Um diese Redundanz zu vermindern, könnte ein [[Mixin]] verwendet werden, falls die Sprache so etwas unterstützt.&lt;br /&gt;
&lt;br /&gt;
== Bewertung ==&lt;br /&gt;
Es lässt sich nicht unabhängig vom konkreten Anwendungsfall festlegen, ob &amp;lt;code&amp;gt;Kreis&amp;lt;/code&amp;gt; sich als Spezialisierung von &amp;lt;code&amp;gt;Ellipse&amp;lt;/code&amp;gt; eignet oder nicht. Im Wesentlichen hängt es davon ab, ob eine Ellipse nach [[Objekt (Programmierung)#Instanziierung|Instanziierung]] in der Größe anpassbar sein soll oder nicht.&lt;br /&gt;
&lt;br /&gt;
== Literatur ==&lt;br /&gt;
*Charles F. Bowman: &amp;#039;&amp;#039;Wisdom of the gurus: a vision for object technology&amp;#039;&amp;#039;. Cambridge University Press, 1996, ISBN 0-13-499849-9&lt;br /&gt;
&lt;br /&gt;
== Einzelnachweise ==&lt;br /&gt;
&amp;lt;references /&amp;gt;&lt;br /&gt;
&lt;br /&gt;
[[Kategorie:Objektorientierte Programmierung]]&lt;/div&gt;</summary>
		<author><name>imported&gt;AX29</name></author>
	</entry>
</feed>