Java에서 인터페이스 구현을 동적으로 검색
객체 지향 프로그래밍에서는 인터페이스 구현 목록을 얻는 것이 도움이 될 수 있습니다. 프로그래밍 방식으로 인터페이스가 제공됩니다. Java에서는 리플렉션과 같은 다양한 기술을 통해 이를 달성할 수 있습니다.
한 가지 접근 방식은 클래스를 내부적으로 검사하고 클래스 정보를 추출하기 위한 편리한 메커니즘을 제공하는 Reflections 라이브러리를 사용하는 것입니다. Reflections를 사용하여 이 작업을 수행할 수 있는 방법은 다음과 같습니다.
import org.reflections.Reflections; import org.reflections.SubTypesScanner; // Define the interface of interest interface Pet {} // Implementations of the Pet interface class Dog implements Pet {} class Cat implements Pet {} // Use Reflections to get a list of Pet implementations Reflections reflections = new Reflections("package.containing.implementations"); Set<Class<? extends Pet>> petImplementations = reflections.getSubTypesOf(Pet.class); // Iterate over and display the implementations for (Class<? extends Pet> implementation : petImplementations) { System.out.println(implementation.getSimpleName()); // prints Dog, Cat }
또는 Java의 ServiceLoader 기능을 활용하여 SPI(서비스 공급자 인터페이스)에 대한 구현을 검색할 수 있습니다.
import java.util.ServiceLoader; // Define the Pet interface as an SPI interface Pet {} // Implementations of the Pet interface class Dog implements Pet {} class Cat implements Pet {} // Use ServiceLoader to load implemented services ServiceLoader<Pet> loader = ServiceLoader.load(Pet.class); // Iterate over and display the implementations for (Pet implementation : loader) { System.out.println(implementation.getClass().getSimpleName()); // prints Dog, Cat }
이 접근 방식을 사용하려면 인터페이스의 정규화된 파일을 사용하여 resources/META-INF/services 디렉터리에 파일을 생성하여 인터페이스를 SPI로 지정해야 합니다. 이름을 지정하고 그 안에 있는 구현을 나열합니다.
또 다른 옵션은 패키지 수준 주석을 정의하는 것입니다.
import java.lang.annotation.Retention; import java.lang.annotation.RetentionPolicy; // Package-level annotation to define implementations @Retention(RetentionPolicy.RUNTIME) @Target(ElementType.PACKAGE) public @interface MyPackageAnnotation { Class<?>[] implementationsOfPet() default {}; } // Implementations of the Pet interface class Dog implements Pet {} class Cat implements Pet {} // Define the package-level annotation in a package-info.java file @MyPackageAnnotation(implementationsOfPet = {Dog.class, Cat.class}) package package.containing.implementations; // Iterate over and display the implementations Package[] packages = Package.getPackages(); for (Package p : packages) { MyPackageAnnotation annotation = p.getAnnotation(MyPackageAnnotation.class); if (annotation != null) { Class<?>[] implementations = annotation.implementationsOfPet(); for (Class<?> implementation : implementations) { System.out.println(implementation.getSimpleName()); } } }
이 접근 방식은 ClassLoader에 이미 알려진 패키지에 대해서만 작동한다는 점을 명심하세요. 보다 철저한 검색을 위해서는 URLClassLoaders를 고려하세요. 하지만 로드된 클래스와 관련된 제한 사항에 유의하세요.
위 내용은 Java 인터페이스 구현을 동적으로 검색하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!