Fachkonzept - Beziehung
Wie verwaltet man Beziehungen?
Unter den vielen Beziehungen zwischen Objekten in unserer Lebenswelt spielt die kennt-Beziehung eine wichtige Rolle.
Ein Objekt Peter
kann einem Objekt Anna
nur dann eine SMS mir einer Einladung zu einem Treffen schicken,
wenn das Objekt Peter
das Objekt Anna
kennt (genauer: die Telefonnummer des Objekts Anna
).
Ähnlich verhält es sich in der Welt der Software-Objekte. Ein Software-Objekt kann nur dann ein anderes Software-Objekts veranlassen, eine Methode auszuführen, wenn es dieses andere Software-Objekt kennt (genauer: die Speicheradresse des anderen Software-Objekts).
Um ein solches In-Beziehung-Setzen von Software-Objekte zu realisieren, werden bestimmte Software-Objekte mit Attributen versehen, mit deren Hilfe sie Referenzen auf "Beziehungspartner" verwalten können.
Fachkonzept - Beziehung
Wir betrachten als Beispiel ein Roboter
-Objekt und Welt
-Objekt.
Ein Roboter
-Objekt verfügt hier über ein ein sogenanntes
Referenzattribut, dessen Wert eine Referenz
bzw. ein Zeiger auf ein Welt
-Objekt ist. Zur Erinnerung:
Die Referenz bzw. der Zeiger ist nichts anderes als die
Adresse, unter der das Objekt im Speicher zu finden ist.
Mit Hilfe eines Aufrufs wie z.B. rob.welt
kann das Roboter
-Objekt rob
jetzt auf Daten des zugeordneten Welt
-Objekts
zugreifen, z.B. mit rob.welt.felderX
auf das entsprechende Attribut.
Das Roboter
-Objekt rob
steht somit in Beziehung zum Welt
-Objekt
welt
.
Verallgemeinernd lässt sich das Beziehungskonzept so beschreiben:
Wenn ein Objekt über einen Zeiger (eine Referenz) Zugriff auf ein anderes Objekt hat, so liegt eine (gerichtete) Beziehung zwischen den Objekten vor.
Um zu verdeutlichen, dass Objekte einer Klasse in Beziehung zu Objekten einer anderen Klasse stehen, wird im Klassendiagramm diese Beziehung durch einen Pfeil verdeutlicht. Die Beziehung kann - wie im folgenden Diagramm zu sehen - zusätzlich mit einem Bezeichner genauer beschrieben werden.
Beziehungsmuster
Im Folgenden werden einige Möglichkeiten aufgezeigt, wie Objekte miteinander in Beziehung stehen können.
Muster: Objekt der Klasse A kennt Objekt der Klasse B
Objektdiagramm:
Klassendiagramm:
Muster: Objekt der Klasse A kennt Objekt der Klasse B und umgekehrt
Objektdiagramm:
Klassendiagramm:
Muster: Objekt der Klasse A kennt mehrere Objekte der Klasse B
Objektdiagramm:
Klassendiagramm:
Beachte im letzten Muster die zusätzlichen Angaben im Klassendiagramm. Mit der Eins und dem Stern am Pfeil wird hier beschrieben, dass 1 Objekt der Klasse A * (d. h. mehrere) Objekte der Klasse B kennt.
Objekt erzeugt Objekt
Eine besondere Form der Beziehung liegt vor, wenn ein Objekt ein anderes erzeugt (und wieder vernichtet) und somit die Kontrolle über die Existenz des verwalteten Objekts hat.
Wenn beispielsweise das Objekt a
eine Methode ausführt, innerhalb derer ein Aufruf zur
Erzeugung eines Objekts b
vorkommt,
so liegt die im Objektdiagramm gezeigte Situation vor:
Im Klassendiagramm wird diese Form der Abhängigkeit wie folgt beschrieben:
Kennt- und hat-Beziehung
Man unterscheidet zwischen einer kennt-Beziehung, bei der die beteiligten Objekte ein Eigenleben führen, und einer hat-Beziehung, bei der ein Objekt auch für die Erzeugung (und Vernichtung) des anderen Objekts zuständig ist.