Wissensdatenbank Wirtschaftsrecht

aktuelles Dokument: ObjProg06Vererbung
image4
image3
image2
image1
 Alle Kategorien:
  Forschungsdatenbank
  Lehrveranstaltungen
  Lexikon
  Literatur
  Rechtsgebiete
  Rechtsprechung
  Service
  Studium F H S
  Wissensmanagement
ich war hier: ObjProg06Vererbung

Revision history for ObjProg06Vererbung


Revision [83273]

Last edited on 2017-08-16 15:17:34 by ClaudiaMichel
Additions:
CategoryObjektorientierteProgrammierung
Deletions:
CategoryDelete


Revision [72102]

Edited on 2016-09-27 12:42:20 by NicoleHennemann
Additions:
CategoryDelete
Deletions:
CategoryObjProg


Revision [26642]

Edited on 2013-04-29 20:31:14 by RonnyGertler
Additions:
=====6.3. Mehrfachvererbung=====


Revision [26641]

Edited on 2013-04-29 20:30:21 by RonnyGertler

No Differences

Revision [26640]

Edited on 2013-04-29 20:28:49 by RonnyGertler
Additions:
""<table class="data" width="80%">
Deletions:
""<table class="date" width="80%">


Revision [26639]

Edited on 2013-04-29 20:28:15 by RonnyGertler
Additions:
b1.ma(); ""//Fehler""
Deletions:
b1.ma(); //Fehler


Revision [26638]

Edited on 2013-04-29 20:27:27 by RonnyGertler
Additions:
""<table class="date" width="80%">
<tr>
<td>
<b>
durch Attribut
</b>
</td>
<td>
<b>
durch Vererbung
</b>
</td>
</tr>
<tr>
<td>
<b>
class A{}; <br/>
class B{ public: A a1;}; <br/>
class B{ private: A a1;};
</b>
</td>
<td>
<b>
class A{}; <br/>
class B :public A{}; <br/>
class B :private A{};
</b>
</td>
</tr>
<tr>
<td>
<b>
Elementinitialisierer für
unlösbares Teilobjekt a1:<br/>
B::B(A a):a1(a){}
</b>
</td>
<td>
<b>
Basisinitialisierer für
namenloses Teilobjekt:<br/>
B::B(A a):A(a){}
</b>
</td>
</tr>
<tr>
<td>
<b>
Objekt-Beziehung,
Hat-Beziehung,
has_a-Beziehung,
Aggregation, Komposition,
Horizontale
Wiederverwendung
</b>
</td>
<td>
<b>
Klassen-Beziehung,
Ist-Beziehung,
is_a-Beziehung,
Spezialisierung,
Vertikale
Wiederverwendung
</b>
</td>
</tr>
</table>""


Revision [26636]

Edited on 2013-04-29 20:14:15 by RonnyGertler
Additions:
Zur Implementierung der neuen Methoden kann bereits vorhandener Code aus der Basisklasse verwendet werden (Implementierungsvererbung).
===Wiederverwendung===
Eine Klasse kann verwendet werden, um neue Objekte zu definieren.
class A{};
main(){ A a1;}
Eine Klasse kann wiederverwendet werden, um neue Klassen zu definieren:
1) Eine Klasse wird wiederverwendet, indem Objekte dieser Klasse als Attribute in anderen Klassen benutzt werden.
class A{};
class B{ A a1;};
2) Wiederverwendung durch Vererbung.
class A{}; class B :public A{};
===Zwei Formen der Wiederverwendung===


Revision [26635]

Edited on 2013-04-29 20:10:06 by RonnyGertler
Additions:
===private- und protected- Vererbung===
In beiden Fällen ist es notwendig, in der abgeleiteten Klasse völlig neue Schnittstelle zu definieren. Ein Objekt vom Typ der abgeleiteten Klasse ist damit kein spezielles Objekt der Basisklasse. Die Ist-Beziehung geht verloren.
{
public: int ma();
class B : private A{};
B b1;
b1.ma(); //Fehler


Revision [26634]

Edited on 2013-04-29 20:07:19 by RonnyGertler
Additions:
Es gibt zwei Möglichkeiten für die Implementierung der neuen redefinierten Methode der abgeleitete Klasse:
1) komplette Neuimplementierung,
2) Aufruf der verdeckten Methode der Basisklasse mit anschließender Ergänzung.
{
public: void m();
};
class B : public A
{
public: void m(int )
{
A::m(); … ;
}
};
""⇒"" Demo 5
===Abgeleitete Klasse mit eigenen Heapdaten===
Wenn die abgeleitete Klasse selbst dynamischen Daten im Heap verwaltet, dann sind folgende Methoden selbst zu definieren:
1) einen Konstruktor (oder mehrere Konstruktoren),
2) einen Destruktor,
3) einen Kopierkonstruktor und
4) einen Zuweisungsoperator.
Ein selbstdefinierter Kopierkonstruktor muss den Kopierkonstruktor der Basisklasse explizit aufrufen. Sonst wird nur Default-Konstruktor der Basisklasse automatisch aufgerufen. ´
{
B(const B & alt) :A(alt){ … }
Ein selbstdefinierter Zuweisungsoperator muss den Zuweisungsoperator der Basisklasse explizit aufrufen.
{
B& B::operator=(const B & alt)
{
… ;
A::operator=(alt);
… ;
}
};
""⇒"" Demo 6
""⇒"" Demo 7
===Vererbung von Zugriffsrechten===
Das Zugriffsrecht des Basisklasse-Elementes in der abgeleiteten Klasse:
{{image url="oop35.gif" width="500"}}
__protected__-Attribute und Methoden sind in der eigenen und in der abgeleiteten Klassen zugreifbar, nicht aber in anderen Klassen oder außerhalb der Klasse.
""⇒"" Demo 8


Revision [26633]

Edited on 2013-04-29 20:01:21 by RonnyGertler
Additions:
Eine Redefinition ist die Definition einer Methode in der abgeleiteten Klasse, wenn die Basisklasse eine Methode mit gleichem Namen hat. Durch Redefinition werden die Methoden an die neuen Fähigkeiten der Klasse angepasst.
Bei einer Redefinition darf die Signatur und der Rückgabe-Typ beider Methoden verschieden sein. Eine Überladung von Methoden findet dabei nicht statt, da die abgeleitete Klasse einen neuen Geltungsbereich besitzt.
Der Compiler sucht den Namen einer öffentlichen aufzurufenden Methode zunächst in der abgeleiteten Klasse.
Findet er diesen nicht, so geht er in der Klassenhierarchie eine Stufe höher. Dank diesem Such-Verfahren wird eine Methode der Basisklasse durch die neue redefinierte Methode verdeckt.
class A
{
public: void m();
class B : public A
{
public: void m(int );
main ()
{
B b1;
b1.A::m( );


Revision [26631]

Edited on 2013-04-29 19:59:29 by RonnyGertler
Additions:
class A {
private: int zet;
public: void setZet(int z) { //eventuelle Kontrolle
zet = z;
}
main () {
A a1;
a1.zet = 5; //Fehler
a1.setZet(5); //OK
}
===Basisinitialisierer ===
Ein Basisinitialisierer dient für den Aufruf eines Konstruktors der Basisklasse und wird in der Initialisierungsliste angegeben.
{{image url="oop33.gif" width="500"}}
""⇒"" Demo 3
""⇒"" Demo 4
Deletions:
class A
{ private: int zet;
public: void setZet(int z)
{ //eventuelle Kontrolle
zet = z;
}
};
main ()
{ A a1; a1.zet = 5; //Fehler
a1.setZet(5); //OK
}


Revision [26630]

Edited on 2013-04-29 19:57:16 by RonnyGertler
Additions:
=====6.2. Einfache Vererbung =====
===Aufbau des Objektes abgeleiteter Klasse===
Alle Konstruktoren einer abgeleiteten Klasse müssen neu definiert werden. Sonst existieren nur Standard-Konstruktoren.
Bei der Initialisierung eines Objektes, welches Teilobjekt der Basisklasse enthält, sind mehrere Konstruktoren auszuführen.
**Reihenfolge der Konstruktor- Aufrufe: **
1) Konstruktor der Basisklasse. Ohne weitere Angabenwird der Default- Konstruktor aufgerufen.
2) Konstruktoren für alle Attribute-Objekte.
3) Konstruktor der abgeleiteten Klasse.
""⇒"" Demo 2
===Aufbau des Teilobjektes===
Der Aufruf von Default-Konstruktoren beim Aufbau von Teilobjekten hat folgende Nachteile:
1) Ein Teilobjekt der Basisklasse wird zwei mal mit Werten versehen:
a) zuerst durch den Aufruf des Default-Konstruktors der Basisklasse,
b) danach durch die Zuweisung beim Aufruf des Konstruktors der abgeleiteten Klasse. Diese doppelte Aktion beeinträchtigt die Ausführungszeit.
2) Die private- Attribute der Basisklasse werden durch Aufrufe der entsprechenden Zugriffsmethoden mit richtigen Anfangswerten versehen.
3) Konstante Objekte können nicht durch die Zuweisung mit Werten versehen werden.
4) Eine Klasse ohne Default-Konstruktor kann nicht als Basisklasse verwendet werden.
===Zugriffsmethoden===
Zugriffsmethoden gewährleisten den kontrollierten Zugriff auf die geschützten Attribute des Objektes.
class A
{ private: int zet;
public: void setZet(int z)
{ //eventuelle Kontrolle
zet = z;
}
};

main ()
{ A a1; a1.zet = 5; //Fehler
a1.setZet(5); //OK
}


Revision [26629]

Edited on 2013-04-29 19:54:28 by RonnyGertler
Additions:
__Klassenhierarchie __ist ein Satz von verwandten Klassen.
**Beispiel:**

class A{ };
class B :public A { };
class C :public A { };

__Generalisierung __(Abstraktion) ist die Entwicklung der Basisklasse durch die Zusammenfassung von ähnlichen Eigenschaften und Verhaltensweisen (Attribute und Methoden) der vielen abgeleiteten Klassen.
a) Die Basisklasse ist eine Generalisierung der abgeleiteten Klassen.
b) In der Klassenhierarchie bedeutet das die Richtung nach oben.
__Spezialisierung __(Konkretisierung) ist die Entwicklung der abgeleiteten Klasse durch die Ergänzung der Basisklasse mit der zusätzlichen Eigenschaften und Verhaltensweisen.
a) Die abgeleitete Klasse ist eine Spezialisierung der Basisklasse.
b) In der Klassenhierarchie bedeutet das die Richtung nach unten.
""⇒"" Demo 1
===Vorteile der Vererbung ===
1) **Datenabstraktion**
Allgemeine Eigenschaften und Vorgänge können mit Oberbegriffen versehen werden (Basisklassen).
Komplexe Sachverhalte werden dadurch einfacher darstellbar. Einige Klassen sind sehr kompliziert aufgebaut, besitzen aber eine einfache Schnittstelle.
2) **Wiederverwendbarkeit**
Bereits erstellte und ausgetestete Klassen können weiterhin verwendet und an neue Anforderungen angepasst werden. Dazu braucht nicht die Implementierung der Basisklasse, sondern nur ihre öffentliche Schnittstelle bekannt zu sein.


Revision [26627]

Edited on 2013-04-29 19:51:23 by RonnyGertler
Additions:
===public- Vererbung===
Bei der public- Vererbung steht die abgeleitete Klasse zur Basisklasse in einer Ist-Beziehung.
Ein Objekt b1 der abgeleitete Klasse B ist auch ein (spezielles) Objekt der Basisklasse A, weil b1 alle Methoden der Basisklasse A automatisch besitzt und sich so wie ein Objekt der Basisklasse A verhält.
{{image url="oop33.gif" width="400"}}
===Schnittstelle abgeleiteter Klasse===
Die Deklarationen von allen public- Methoden bilden die öffentliche Schnittstelle (Interface). Durch diese Methoden kommuniziert ein Objekt mit der Umgebung.
Die öffentliche Schnittstelle der abgeleiteten Klasse besteht aus:
1) der öffentlichen Schnittstelle der Basisklasse und
2) den in der abgeleiteten Klasse zusätzlich deklarierten public-Methoden (und public- Attributen).
===Vererbung der Schnittstelle===
Die Schnittstelle der Basisklasse wird geerbt, wenn die öffentliche Methoden der Basisklasse durch Objekte der abgeleiteten Klasse aufgerufen werden dürfen.
===Vererbung der Implementierung===
Die Implementierung der Basisklasse wird geerbt, wenn öffentliche Methoden der Basisklasse zwar innerhalb der abgeleiteten Klasse aufgerufen werden dürfen. Der Code der Basisklasse wird dabei wiederverwendet.
===Varianten der Vererbung===
1) **Öffentliche Vererbung**
Vererbung von Schnittstelle und Implementierung.
class A{ };
class B :public A { };

2) **Private Vererbung**
Reine Vererbung derImplementierung.

class A{ };
class B :private A { };

3) **Einfache Vererbung**
Eine Klasse erbt von einer anderen Klasse.
class A{ };
class B :public A { };
4) **Mehrfachvererbung**
Eine Klasse erbt von mehreren Klassen.
class A{ }; class B{ };
class C :public A, public B { };


Revision [26625]

Edited on 2013-04-29 19:47:04 by RonnyGertler
Additions:
{{image url="oop31.gif" width="400"}}
Deletions:
{{image url="oop31.gif" width="500"}}


Revision [26624]

Edited on 2013-04-29 19:46:46 by RonnyGertler
Additions:
{{image url="oop30.gif" width="200"}}
===UML- Klassendiagramm ===
{{image url="oop31.gif" width="500"}}
===Zugriff auf Teilobjekt der Basisklasse===
{{image url="oop32.gif" width="500"}}
Deletions:
{{image url="oop30.gif" width="300"}}


Revision [26623]

Edited on 2013-04-29 19:45:46 by RonnyGertler
Additions:
{{image url="oop29.gif" width="550"}}
===class A===
**Beispiel in C++**
%%(cpp)
{ private: int x;
public: int ma();
};
class B :public A
{ private: int y;
public: int mb();
};
main()
{ B b1;
}
%%
{{image url="oop30.gif" width="300"}}
Deletions:
{{files}}


Revision [26619]

The oldest known version of this page was created on 2013-04-29 19:34:26 by RonnyGertler
Valid XHTML   |   Valid CSS:   |   Powered by WikkaWiki