Statische Methoden imitieren
Ich weiß, ist ein komischer Titel, aber irgendwie ist mir kein besserer Name eingefallen. Heute geht es wieder um Legacy Code. Im täglichen Gebrauch von „altem“ Code muss man immer wieder statische Methoden in bereits vorhandenen Klassen implementieren. Da man in PHP 4 noch nicht viel mit statischen Methoden oder Attributen anfangen konnte wurde die meisten Probleme ohne dies gelöst. Was ja auch legitim ist für diese Zeit. Jetzt mit PHP5 und einer besseren aber nicht perfekten Unterstützung des static Schlüsselwortes möchte man aber vielleicht trotzdem der Klasse eine statische Methode hinzufügen. Oft wird es aber dadurch erschwert, dass man in diesem statischen Kontext auf eine Instanzmethode zugreifen muss, da sie damals einfach nicht als statisch definiert wurde. Aus der Erfahrung heraus weiß ich, dass viele dieses Problem lösen, indem sie diese Methode auch als Instanzmethode definieren und somit auf den statischen Kontext verzichten. Auf diese Weise müsste man dann halt jedes mal vor dem Aufruf dieser Methode eine Instanz explizit erstellen. Da man aber eh jedes mal über eine Instanz gehen muss, kann man auch diese Instanz gleich in der Methode selbst erstellen und diese dann doch wieder statisch machen.
<?php class OldClass { var $className = "OldClass"; public function getClassName( ) { return $this->className( ); } } ?>
Hier hätten wir so einen Fall. Eigentlich müsste das Attribut $className
eine Konstante und die Methode getClassName
sollte statisch sein. Wenn man jetzt nämlich eine Methode bräuchte, die zum Beispiel den Klassennamen als kleingeschriebenen String bräuchte, so müsste man diese jetzt eigentlich auch als Instanzmethode definieren. Aber wie bereits gesagt halte ich folgenden Ansatz für besser:
<?php class OldClass { var $className = "OldClass"; public function getClassName( ) { return $this->className( ); } public static function getLowerCaseClassName( ) { $class = new self; return strtolower( $class->getClassName( ) ); } } ?>
Ich muss dazu sagen, dass dies nur einer von vielen Ansätzen ist, die man gehen kann. Ich denke in vielen Fällen ist dies ein eleganterer als über eine Instanzmethode zu gehen. Es ist aber ganz klar, dass es noch schöner wäre, wenn man ganz ohne diese Tricks auskommt, weil die Klasse bereits die richtigen Kontexte für ihre Methoden bereitstellt. Aber wie es nun mal ist, leben wir nicht in einer perfekten Welt und legacy code wird es immer geben.