Exkurs - Implementierung in Python

Deklaration einer Klasse

Am Beispiel der Klasse Kartenhaufen sollen die Besonderheiten aufgezeigt werden, die man bei der Implementierung von Klassen in Python beachten muss.

Ausgangspunkt ist das folgende Klassendiagramm, das die Struktur der Klasse Kartenhaufen beschreibt.

Klassendiagramm

Eine Implementierung in Python könnte wie folgt aussehen (beachte, dass auch andere Implementierungen möglich sind):

class Kartenhaufen(object):
    def __init__(self):
        self.kartenListe = []
        self.wert = 0

    def hinzufuegen(self, karte):
        self.kartenListe = self.kartenListe + [karte]
        if karte[2] == 'A':
            kartenwert = 11
        elif karte[2] == 'K':
            kartenwert = 4
        elif karte[2] == 'D':
            kartenwert = 3
        elif karte[2] == 'B':
            kartenwert = 2
        elif karte[2] == '1':
            kartenwert = 10
        elif karte[2] == '9':
            kartenwert = 9
        elif karte[2] == '8':
            kartenwert = 8
        elif karte[2] == '7':
            kartenwert = 7
        self.wert = self.wert + kartenwert

Eine Klassendeklaration wird immer mit dem Schlüsselwort class eingeleitet. Es folgt der Klassenname und in Klammern die Oberklasse, von der die neue Klasse abgeleitet wird. Mehr hierzu wird im Abschnitt "Vererbung" erläutert. Im vorliegenden Fall ist die Oberklasse die vom Python-System vorgegebene Klasse object, die man immer dann verwenden sollte, wenn keine speziellen Oberklassen vorgesehen sind.

Der Konstruktor (einer jeden Klasse) wird in Python mit __init__ bezeichnet (beachte: zwei Unterstrichen vor und nach dem Wort init). Beachte, dass Klassendiagramme programmiersprachenunabhängig erstellt werden. Der Konstruktor wird daher im Klassendiagramm und der zugehörigen Python-Implementierung unterschiedlich dargestellt.

Der Konstruktor verwendet - wie auch alle anderen Methoden - einen ersten Parameter self. Dieser Parameter wird bei der Ausführung der Methode durch das betreffende Objekt aktualisiert. Dieser Parameter darf nicht fehlen, da mit ihm in Python eine Prozedur- bzw. Funktionsdeklaration erst zu einer Methodendeklaration innerhalb einer Klasse wird. Man darf den Parameter aber anders benennen. Wir verzichten darauf und benutzen die übliche Konvention, ihn mit self zu bezeichnen.

Bei der Implementierung des Konstruktors sollten alle Attribute eingeführt und gegebenenfalls mit Anfangswerten versehen werden. Hierdurch verschafft man sich einen Überblick über sämtliche Attribute der Klasse.

Attribute werden in Python in der Form self.attributname dargestellt, wobei hier der erste Parameter der Methodendeklaration (hier also self) dem Attributnamen vorangestellt wird. Im Klassendiagramm wird dieser Python-spezifische Zusatz nicht aufgeführt.

Beachte, dass jede Methode einen ersten Parameter self hat (s. o.). Im Klassendiagramm wird dieser Python-spezifische Zusatzparameter nicht aufgeführt.

Erzeugung von Objekten

Zur Erzeugung eines Objekts muss der Konstruktor der zugehörigen Klasse aufgerufen werden. In Python erreicht man dies, indem man den Klassennamen wie im folgenden Protokoll aufruft.

>>> meinKartenhaufen = Kartenhaufen()
>>> meinKartenhaufen
<__main__.kartenhaufen object at>
>>> meinKartenhaufen.__dict__
{'wert': 0, 'kartenListe': []}

Inspektion von Objekten

Das Protokoll zeigt auch, wie man sich in Python direkt einen Überblick über sämtliche Attribute und Attributwerte eines Objekts verschafft. Mit einem Aufruf der Gestalt objekt.__dict__ erhält man den aktuellen Objektzustand.

Vernichtung von Objekten

Der Python-Dialog unten zeigt, wie man ein Objekt gezielt vernichten kann und somit einen Destruktor aktivieren kann. Python übernimmt das Vernichten von Objekten selbst, so dass wir uns in der Regel darum nicht kümmern müssen.

>>> meinKartenhaufen = Kartenhaufen()
>>> meinKartenhaufen
<__main__.kartenhaufen object at>
>>> del meinKartenhaufen
>>> meinKartenhaufen
Traceback (most recent call last):
  File ...
    ampel1
NameError: name 'meinKartenhaufen' is not defined
>>> 
X

Fehler melden

X

Suche