Unterschiede
Hier werden die Unterschiede zwischen zwei Versionen angezeigt.
Beide Seiten der vorigen Revision Vorhergehende Überarbeitung Nächste Überarbeitung | Vorhergehende Überarbeitung | ||
modul:m320_2024:learningunits:lu08:einseitigebeziehung [2024/09/12 13:06] – msuter | modul:m320_2024:learningunits:lu08:einseitigebeziehung [2024/09/18 13:12] (aktuell) – msuter | ||
---|---|---|---|
Zeile 4: | Zeile 4: | ||
* einseitge Beziehungen | * einseitge Beziehungen | ||
* zweiseitige Beziehungen | * zweiseitige Beziehungen | ||
- | |||
- | === Einseitige Beziehung === | ||
Bei einer einseitigen Beziehung kennt ein Objekt " | Bei einer einseitigen Beziehung kennt ein Objekt " | ||
- | === Beispiel: Geldbeutel und Besitzer === | + | ===== Beispiel: Geldbeutel und Besitzer |
+ | ==== Klassendiagramm ==== | ||
- | {{: | + | {{: |
//Abb: Klassen in einer einseitigen Beziehung// | //Abb: Klassen in einer einseitigen Beziehung// | ||
Zeile 18: | Zeile 17: | ||
Daher wird hier die Referenz über eine Methode gesetzt. | Daher wird hier die Referenz über eine Methode gesetzt. | ||
So sind die Erzeugung des Personen-Objekts und die Zuweisung der Referenz zeitlich unabhängig. | So sind die Erzeugung des Personen-Objekts und die Zuweisung der Referenz zeitlich unabhängig. | ||
+ | |||
+ | ==== Sequenzdiagramm ==== | ||
Dies zeigt das zugehörige Sequenz-Diagramm eindeutig auf. | Dies zeigt das zugehörige Sequenz-Diagramm eindeutig auf. | ||
- | {{: | + | {{: |
//Abb: Sequenz-Diagramm der Zuweisung einer einseitigen Beziehung über eine Methode // | //Abb: Sequenz-Diagramm der Zuweisung einer einseitigen Beziehung über eine Methode // | ||
- | === Beispiel: Stromschalter und Wippe (Aktuator) === | + | ==== Sourcecode ==== |
+ | <code python> | ||
+ | class Person: | ||
+ | |||
+ | def __init__(self, name): | ||
+ | self._name | ||
+ | self._wallet | ||
+ | |||
+ | @property | ||
+ | def name(self): | ||
+ | return self._name | ||
- | {{: | + | @property |
+ | def wallet(self): | ||
+ | return self._wallet | ||
+ | |||
+ | @wallet.setter | ||
+ | def wallet(self, | ||
+ | self._wallet = wallet | ||
+ | |||
+ | class Wallet: | ||
+ | |||
+ | def __init__(self): | ||
+ | pass | ||
+ | |||
+ | def deposit_money(self, | ||
+ | pass | ||
+ | |||
+ | def withdraw_money(self, | ||
+ | pass | ||
+ | |||
+ | if __name__ == ' | ||
+ | person = Person(' | ||
+ | wallet = Wallet() | ||
+ | person.wallet = wallet | ||
+ | |||
+ | </ | ||
+ | |||
+ | ===== Beispiel: Stromschalter und Wippe (Aktuator) ===== | ||
+ | ==== Klassendiagramm ==== | ||
+ | |||
+ | {{: | ||
//Abb: Klassen in einer einseitigen Beziehung// | //Abb: Klassen in einer einseitigen Beziehung// | ||
Zeile 36: | Zeile 76: | ||
In diesem Fall ist es zwingend, dass die Wippe zeitlich zuerst erzeugt wird, so dass ihre Referenz verfügbar ist. | In diesem Fall ist es zwingend, dass die Wippe zeitlich zuerst erzeugt wird, so dass ihre Referenz verfügbar ist. | ||
- | {{: | + | ==== Sequenzdiagramm ==== |
+ | |||
+ | {{: | ||
//Abb: Sequenz-Diagramm der Zuweisung einer einseitigen Beziehung über den Konstruktor// | //Abb: Sequenz-Diagramm der Zuweisung einer einseitigen Beziehung über den Konstruktor// | ||
+ | ==== Sourcecode ==== | ||
+ | |||
+ | <code python> | ||
+ | class PowerSwitch: | ||
+ | |||
+ | def __init__(self, | ||
+ | self._type | ||
+ | self._actuator = actuator | ||
+ | |||
+ | @property | ||
+ | def type(self): | ||
+ | return self._type | ||
+ | |||
+ | class Actuator: | ||
+ | | ||
+ | def __init__(self): | ||
+ | self._position = False | ||
+ | |||
+ | def press(self): | ||
+ | pass | ||
+ | |||
+ | def release(self): | ||
+ | pass | ||
+ | |||
+ | def is_pressed(self): | ||
+ | return self._position | ||
+ | |||
+ | if __name__ == ' | ||
+ | actuator = Actuator() | ||
+ | switch = PowerSwitch(' | ||
+ | |||
+ | </ | ||
---- | ---- | ||
{{tag> | {{tag> | ||
[[https:// | [[https:// | ||