Hook (Informatik)Hook (englisch für Haken, auch Einschubmethode genannt) bezeichnet in der Programmierung eine Schnittstelle, mit der fremder Programmcode in eine bestehende Anwendung integriert werden kann, um diese zu erweitern, deren Ablauf zu verändern oder um bestimmte Ereignisse abzufangen. Dies kann entweder im Quelltext geschehen, der entsprechend modifiziert wird, über Konfigurationsdateien, die den Ablauf eines fertigen Programms verändern, oder über Aufruf von Funktionen, denen der auszuführende Programmcode in irgendeiner Form mitgegeben wird. In der Regel ist das Standardverhalten von Einschubmethoden, gar nichts zu tun.[1] Hooks können auch vom Betriebssystem zum Abfangen von Nachrichten zur Verfügung gestellt werden. Damit lassen sich z. B. systemweite Hotkeys implementieren.[2] So können zum Beispiel über einen Hook die Tastatur-Nachrichten unabhängig von dem Programm, welches aktuell den Fokus hat, empfangen werden. ImplementierungEs gibt mehrere Möglichkeiten, Hooks zu implementieren. Wenn der Quelltext des zu erweiternden Programms vorliegt, lassen sich prinzipiell immer Erweiterungen vornehmen. Sofern der Code jedoch nicht genau bekannt ist, ist dieses aufwendig, weil diese Erweiterung eventuell umfangreiche Veränderungen erfordert, die obendrein unerwünschte Nebenwirkungen haben können und zudem mit jeder neuen Version neu eingepflegt werden müssten. Daher definieren manche Programme bestimmte Stellen, die explizit dazu vorgesehen sind, von anderen erweitert zu werden. Dies kann dadurch geschehen, dass eine Funktion aufgerufen wird, die im ursprünglichen Programm leer implementiert ist, also nichts bewirkt. Diese kann dann gefahrlos auf eine fremdimplementierte Funktion umgelenkt werden. Die ursprünglich leere Funktion ist dann der Hook. In der objektorientierten Programmierung geschieht dies durch Vererbung oder durch Delegation:
Betriebssystem-Hooks unter Windows werden in einer eigenen DLL implementiert, welche vom Betriebssystem ohne einen Programmkontext aufgerufen wird. Somit muss ein Programm, welches einen Hook (z. B. zur Benachrichtigung über ein Ereignis) implementiert, seine Ergebnisse über andere Mechanismen von dem in der DLL enthaltenen Code erfahren (z. B. mittels Interprozesskommunikation). KonfigurationEs bleibt die Frage, wie das aufrufende Programm Kenntnis von den Programmteilen erlangt, die die bereitgestellten Hooks nutzen wollen. Im einfachsten Fall wird der Programmcode direkt verändert, um Zugriff auf die Hooks zu erlangen. Oder es wird Programmcode über Konfigurationen eingebunden. Dies kann in der prozeduralen Programmierung über Funktionszeiger geschehen, indem eine aufzurufende Unterroutine mit ihrer Startadresse eingetragen wird. In der objektorientierten Programmierung wird dagegen eine Klasse über ihren Namen dynamisch geladen; diese Klasse implementiert dann als Unterklasse oder als Delegationsobjekt den vom Hook aufgerufenen Code. Wird Dependency Injection verwendet, so lassen sich hierüber ebenfalls einfach Hooks konfigurieren. Eine dritte Möglichkeit besteht darin, ein Objekt oder eine Funktion, welche vom Hook aufgerufen werden soll, über eine Zugriffsfunktion zu setzen. Dies wird dann gemacht, wenn der Hook von einer Programmbibliothek bereitgestellt wird, das vom selben Programmteil verwendet wird, welches auch die Hooks nutzen wird. Genutzt wird das beispielsweise beim Listener für Benutzerinteraktionen, welcher oben bereits genannt wurde. Siehe auchEinzelnachweise
|