Dynamische Proxies optimal nutzen

Seit Java SE 1.3 sind dynamische Proxies bereits Bestandteil von Java. Und so definiert sie die Javadoc für die Klasse Proxy: „Eine Klasse dynamischer Proxies ist eine Klasse, die eine Liste von Schnittstellen zur Laufzeit implementiert, wenn die Klasse erzeugt wird.“

Das bedeutet, dass man eine Klasse zur Laufzeit erzeugen kann, die ein oder mehrere Schnittstellen implementiert, die man zur Laufzeit spezifiziert. Diese Funktionalität wird man nicht jeden Tag benötigen, aber sie ist nützlich, wenn man ein Test-Framework oder eine Objekt-Harness entwickelt.

Wie dynamische Proxies funktionieren

Dynamisch Proxies bestehen aus zwei Teilen: einem Invocation-Handler und einer Proxy-Instanz. Ein Invocation-Handler ist eine Klasse, die die Schnittstelle java.lang.reflect.InvocationHandler implementiert. Dies ist die Klasse, welche die von den Schnittstellen – die durch die Proxy-Instanz definierten wurden – angefragten Aufgaben erledigt oder weiterleitet. Die Proxy-Instanz ist ein Objekt, das der Methode übergeben wird, die den zu emulierenden Typ anfordert.

Um einen Proxy zu erstellen, der eine Liste von Schnittstellen implementiert, verwendet man die statische Methode newProxyInstance() der Proxy-Klasse. Die Methode newProxyInstance() akzeptiert drei Argumente: eine Instanz von ClassLoader, ein Array von Klassen-Instanzen sowie eine Instanz von InvocationHandler. Das Array von Klassen bestimmt, welche Schnittstellen die neue Proxy-Instanz implementieren wird, und der InvocationHandler wird aufgerufen, wenn Methoden für die Proxy-Instanz aufgerufen werden.

Das folgende einfache Beispiel erzeugt eine Klasse zur Laufzeit und implementiert entweder das java.lang.Runnable oder die lokal definierte Publisher-Schnittstelle:

Eine Einschränkung von Proxies besteht darin, dass nur Schnittstellen über einen Proxy delegiert werden können. Falls man versucht, einen Proxy für einen anderen Typ als eine Schnittstelle zu erstellen, erhält man eine Exception wie diese:

Der Leistungsfähigkeit von dynamischen Proxies sind nur vom eigenen Erfindungsreichtum und den zur Verfügung stehenden Schnittstellen Grenzen gesetzt. Für weitere Informationen darüber, was man beim Einsatz von Proxies beachten muss, sollte man die Javadoc konsultieren.

ZDNet.de Redaktion

Recent Posts

Gefahren im Foxit PDF-Reader

Check Point warnt vor offener Schwachstelle, die derzeit von Hackern für Phishing ausgenutzt wird.

24 Stunden ago

Bitdefender entdeckt Sicherheitslücken in Überwachungskameras

Video-Babyphones sind ebenfalls betroffen. Cyberkriminelle nehmen vermehrt IoT-Hardware ins Visier.

24 Stunden ago

Top-Malware in Deutschland: CloudEye zurück an der Spitze

Der Downloader hat hierzulande im April einen Anteil von 18,58 Prozent. Im Bereich Ransomware ist…

24 Stunden ago

Podcast: „Die Zero Trust-Architektur ist gekommen, um zu bleiben“

Unternehmen greifen von überall aus auf die Cloud und Applikationen zu. Dementsprechend reicht das Burg-Prinzip…

2 Tagen ago

Google schließt weitere Zero-Day-Lücke in Chrome

Hacker nutzen eine jetzt gepatchte Schwachstelle im Google-Browser bereits aktiv aus. Die neue Chrome-Version stopft…

2 Tagen ago

Hacker greifen Zero-Day-Lücke in Windows mit Banking-Trojaner QakBot an

Microsoft bietet seit Anfang der Woche einen Patch für die Lücke. Kaspersky-Forscher gehen davon aus,…

2 Tagen ago