使用
reflections API肯定会起作用.如果不是,你可能会以错误的方式设置它.我只是编写了这个例子,它独立于任何类加载器打印包中的所有类.
package com.test;
import java.util.Arrays;
import java.util.Iterator;
import java.util.Set;
import org.reflections.Reflections;
import org.reflections.scanners.FieldAnnotationsScanner;
import org.reflections.scanners.MemberUsageScanner;
import org.reflections.scanners.MethodAnnotationsScanner;
import org.reflections.scanners.MethodParameterNamesScanner;
import org.reflections.scanners.MethodParameterScanner;
import org.reflections.scanners.SubTypesScanner;
import org.reflections.scanners.TypeAnnotationsScanner;
import org.reflections.util.ClasspathHelper;
import org.reflections.util.ConfigurationBuilder;
import org.reflections.util.FilterBuilder;
public class Runner {
public static void main(String[] args) {
Reflections reflections = new Reflections();
FilterBuilder TestModelFilter = new FilterBuilder().include("com.test.*");
reflections = new Reflections(new ConfigurationBuilder()
.setUrls(Arrays.asList(ClasspathHelper.forClass(Runner.class))).filterInputsBy(TestModelFilter)
.setScanners(new SubTypesScanner(false), new TypeAnnotationsScanner(), new FieldAnnotationsScanner(),
new MethodAnnotationsScanner(), new MethodParameterScanner(), new MethodParameterNamesScanner(),
new MemberUsageScanner()));
Set> allClasses = reflections.getSubTypesOf(Object.class);
System.out.println(allClasses);
for (Iterator it = allClasses.iterator(); it.hasNext();) {
Class extends Object> clazz = (Class extends Object>) it.next();
System.out.println(clazz.getCanonicalName());
}
}
}
我按意图添加了所有导入,因此您可以查看它使用的API.这对你有用吗?