Programmgesteuertes Abrufen von Klassenimplementierungen einer Schnittstelle in Java
Java Reflection bietet flexible Mechanismen für die Selbstprüfung von Klassen und Schnittstellen. In diesem Zusammenhang können Entwickler Reflection nutzen, um eine Liste aller Klassen abzurufen, die eine bestimmte Schnittstelle implementieren.
Reflexionsbasierter Ansatz
Verwendung der Reflections Bibliothek können Entwickler mühelos Unterklassen einer Schnittstelle abrufen als folgt:
Reflections reflections = new Reflections("firstdeveloper.examples.reflections"); Set<Class<? extends Pet>> classes = reflections.getSubTypesOf(Pet.class);
ServiceLoader-Ansatz
Der Java ServiceLoader bietet einen alternativen Ansatz zum Entdecken von Schnittstellenimplementierungen. Diese Technik erfordert die Definition der Schnittstelle als Service Provider Interface (SPI) und die Deklaration ihrer Implementierungen:
ServiceLoader<Pet> loader = ServiceLoader.load(Pet.class); for (Pet implClass : loader) { System.out.println(implClass.getClass().getSimpleName()); // prints Dog, Cat }
Annotation-Ansatz auf Paketebene
Mit Paket -Level-Annotationen können wir die Implementierungen einer Schnittstelle innerhalb der package-info.java deklarieren file:
@MyPackageAnnotation(implementationsOfPet = {Dog.class, Cat.class}) package examples.reflections;
Dann können wir diese Implementierungen mithilfe von Reflection abrufen:
Package[] packages = Package.getPackages(); for (Package p : packages) { MyPackageAnnotation annotation = p.getAnnotation(MyPackageAnnotation.class); if (annotation != null) { Class<?>[] implementations = annotation.implementationsOfPet(); for (Class<?> impl : implementations) { System.out.println(impl.getSimpleName()); } } }
Das obige ist der detaillierte Inhalt vonWie kann ich programmgesteuert alle Klassen finden, die eine bestimmte Schnittstelle in Java implementieren?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!