Reflections框架,类扫描工具

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());
        }
    }

 

posted @ 2019-04-10 14:16  一心二念  阅读(2663)  评论(0编辑  收藏  举报