Reflections是一个能提供一站式服务的对象。
巧用Reflections库实现包扫描(扫描某个包中某个接口实现、注解等)
它扫描工程的classpath,为元数据建索引,允许你运行时查询元数据信息。此外,他还能为你项目的lib库中所有的jar包保存和收集元数据。
1. 借助它能做什么?
获取某个类型的全部子类
只要类型、构造器、方法,字段上带有特定注解,便能获取带有这个注解的全部信息(类型、构造器、方法,字段)
获取所有能匹配某个正则表达式的资源
获取所有带有特定签名的方法,包括参数,参数注解,返回类型
获取所有方法的名字
获取代码里所有字段、方法名、构造器的使用
2. 相关资料
github地址 : https://github.com/ronmamo/reflections
javadoc地址 : http://ronmamo.github.io/reflections/index.html?org/reflections/Reflections.html
<dependency>
<groupId>org.reflections</groupId>
<artifactId>reflections</artifactId>
<version>0.9.11</version>
</dependency>
使用起来非常简单:
@Test
public void testReflections() {
Reflections reflections = new Reflections("org.fhp.test.entity");
Set<Class<? extends MyInterface>> classes = reflections.getSubTypesOf(MyInterface.class);
for(Class clazz : classes) {
//logger.info(clazz.getName());
System.out.println("Found: " + clazz.getName());
}
}
假如想扫描整个工程的类,直接new一个不带参数的Reflections就好。值得一提的是,这东西在扫描的时候,连依赖的jar包都不放过。以Spring框架的BeanFactory为例:
@Test
public void testReflections() {
Reflections reflections = new Reflections();
Set<Class<? extends BeanFactory>> classes = reflections.getSubTypesOf(BeanFactory.class);
for(Class clazz : classes) {
//logger.info(clazz.getName());
System.out.println("Found: " + clazz.getName());
}
}
另一个常用的场景是扫描包含指定注解的类。reflections对象中同样包含这一方法,代码如下:
@Test
public void testReflections() {
Reflections reflections = new Reflections();
Set<Class<?>> classes = reflections.getTypesAnnotatedWith(Service.class);
for(Class clazz : classes) {
//logger.info(clazz.getName());
System.out.println("Found: " + clazz.getName());
}
}