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

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM