java反射工具Reflections用法
一、引入maven依赖
org.reflections
reflections
0.9.10
二、用法示例:
reflections 中包含很多的Scanner ,也就是扫描器,调用对应的方法时需要有配置对应的扫描器,不然程序会抛出异常.//扫描包含my.package的url,包括'my.package'开头的包路径,使用默认扫描器
Reflections reflections = new Reflections("my.package");public class testReflections {
private static final Reflections reflections;
static {
//如果不加filterInputsBy,那么会扫描classpath,获取当前扫描路径所在项目的所有包
reflections= new Reflections(new ConfigurationBuilder()
.forPackages("com.study.demo")//指定扫描路径
.filterInputsBy(new FilterBuilder().excludePackage("mystu")) //排除某个包,注意不能是扫描包子包,否则不生效
.setScanners(new MethodParameterScanner())// 添加方法参数扫描工具,可以根据需要向该方法传入多个扫描工具
);
}
public static void main(String[] args) {
// 1、根据方法参数,反射获取扫描路径下所有匹配的方法
Set methodsMatchParams = reflections.getMethodsMatchParams(String.class);
methodsMatchParams.forEach(System.out::println);
}
}
相关Api
一些扫描器//SubTypesScanner:子类扫描器
Set> set = reflections.getSubTypesOf(User.class);
// 获取void返回值方法
Set voidMethods = reflections.getMethodsReturn(void.class);
// FieldAnnotationsScanner:被注解字段扫描器,获取特定注解的字段
Set fields = reflections.getFieldsAnnotatedWith(NotNull.class);
ReflectionUtils根据方法的可见性,前缀名,入参个数,获取某个类的对应方法Set getters = ReflectionUtils.getAllMethods(User.class,
withModifier(Modifier.PUBLIC), withPrefix("set"), withParametersCount(1));根据方法入参返回值类获某个类的所有方法//获取List的方法:入参为Collection,返回值为boolean
Set methods = ReflectionUtils.getAllMethods(List.class,
withParametersAssignableTo(Collection.class),
withReturnType(boolean.class));获取某个类特定类型的所有字段//该方法可以传入一些参数,比如过滤出带注解的参数:withAnnotation(NonNull.class)
Set fields = ReflectionUtils.getAllFields(Animal.class, withTypeAssignableTo(String.class));