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