获取所有classpath指定包下类的所有子类

2024-09-08 07:32

本文主要是介绍获取所有classpath指定包下类的所有子类,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.问题

开发过程中,有时需要找到所有classpath下,特定包下某个类的所有子类,如何做到?

2. 实现

比较常见的解决方案是自己遍历目录,查找所有.class文件。
下面这个方法使用spring工具类实现,简化过程,不再需要自己遍历目录

    /*** 获取在指定包下某个class的所有非抽象子类** @param parentClass 父类* @param packagePath 指定包,格式如"com/sinosun/tarvel"* @return 该父类对应的所有子类列表*/private static <E> List<Class<E>> getSubClasses(final Class<E> parentClass, final String packagePath) throws ClassNotFoundException{final ClassPathScanningCandidateComponentProvider provider = new ClassPathScanningCandidateComponentProvider(false);provider.addIncludeFilter(new AssignableTypeFilter(parentClass));final Set<BeanDefinition> components = provider.findCandidateComponents(packagePath);final List<Class<E>> subClasses = new ArrayList<>();for (final BeanDefinition component : components){@SuppressWarnings("unchecked") final Class<E> cls = (Class<E>) Class.forName(component.getBeanClassName());if (Modifier.isAbstract(cls.getModifiers())){continue;}subClasses.add(cls);}return subClasses;}

3. 实例

扫描com.sinosun包下所有CoreStart类的子类,并采用反射的方式依次查看子类中是否启用数据源。

package com.sinosun.travel.core.main;import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.config.BeanDefinition;
import org.springframework.context.annotation.ClassPathScanningCandidateComponentProvider;
import org.springframework.core.type.filter.AssignableTypeFilter;import java.lang.reflect.Constructor;
import java.lang.reflect.Method;
import java.lang.reflect.Modifier;
import java.util.ArrayList;
import java.util.List;
import java.util.Set;/*** @author caogu* @date 2019/5/31 13:36*/
public class DataSourceHandler
{private static final Logger logger = LoggerFactory.getLogger(DataSourceHandler.class);private static final String PARENT_PACKAGE= "com.sinosun";private static final String CORE_START_CLASS_NAME = "com.sinosun.travel.core.main.CoreStart";private static final String IS_ENABLE_DATA_SOURCE_METHOD_NAME = "isEnableDataSource";/*** 根据环境判定是否启用数据源* 默认不启用数据源;扫描CoreStart类的所有子类,若子类中有一个启用数据源则启用数据源* @throws Exception 异常*/public static void scanIsEnableDataSource() throws Exception{List<Class<CoreStart>> coreStartClasses = getSubClasses(CoreStart.class, PARENT_PACKAGE);logger.info("扫描到CoreStart类的子类有:{}", coreStartClasses);for (Class<CoreStart> coreStartClass : coreStartClasses){// 只扫描CoreStart的子类,只要一个启用数据源就启用数据源; 默认不启用数据源// 只检测子类,父类排除if (!CORE_START_CLASS_NAME.equals(coreStartClass.getName())){Constructor constructor = coreStartClass.getConstructor();Object obj = constructor.newInstance();Method[] methods = coreStartClass.getDeclaredMethods();for (Method method : methods){if (IS_ENABLE_DATA_SOURCE_METHOD_NAME.equals(method.getName())){boolean isEnableDataSource = (boolean) method.invoke(obj);logger.info("调用{}.{}方法的返回值为{}", coreStartClass.getName(), coreStartClass.getName(), isEnableDataSource);if (isEnableDataSource){CoreStart.ENABLE_DATA_SOURCE = true;logger.info("扫描到子类启用数据源,加载数据源!");return;}}}}}}/*** 获取在指定包下某个class的所有非抽象子类** @param parentClass 父类* @param packagePath 指定包,格式如"com/sinosun/tarvel"* @return 该父类对应的所有子类列表*/private static <E> List<Class<E>> getSubClasses(final Class<E> parentClass, final String packagePath) throws ClassNotFoundException{final ClassPathScanningCandidateComponentProvider provider = new ClassPathScanningCandidateComponentProvider(false);provider.addIncludeFilter(new AssignableTypeFilter(parentClass));final Set<BeanDefinition> components = provider.findCandidateComponents(packagePath);final List<Class<E>> subClasses = new ArrayList<>();for (final BeanDefinition component : components){@SuppressWarnings("unchecked") final Class<E> cls = (Class<E>) Class.forName(component.getBeanClassName());if (Modifier.isAbstract(cls.getModifiers())){continue;}subClasses.add(cls);}return subClasses;}public static void main(String[] args){System.out.println(System.getProperty("java.class.path"));System.out.println(System.getProperty("user.dir"));}}

结果如下:
在这里插入图片描述

这篇关于获取所有classpath指定包下类的所有子类的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1147498

相关文章

Android Environment 获取的路径问题

1. 以获取 /System 路径为例 /*** Return root of the "system" partition holding the core Android OS.* Always present and mounted read-only.*/public static @NonNull File getRootDirectory() {return DIR_ANDR

遮罩,在指定元素上进行遮罩

废话不多说,直接上代码: ps:依赖 jquer.js 1.首先,定义一个 Overlay.js  代码如下: /*遮罩 Overlay js 对象*/function Overlay(options){//{targetId:'',viewHtml:'',viewWidth:'',viewHeight:''}try{this.state=false;//遮罩状态 true 激活,f

Jenkins构建Maven聚合工程,指定构建子模块

一、设置单独编译构建子模块 配置: 1、Root POM指向父pom.xml 2、Goals and options指定构建模块的参数: mvn -pl project1/project1-son -am clean package 单独构建project1-son项目以及它所依赖的其它项目。 说明: mvn clean package -pl 父级模块名/子模块名 -am参数

C#关闭指定时间段的Excel进程的方法

private DateTime beforeTime;            //Excel启动之前时间          private DateTime afterTime;               //Excel启动之后时间          //举例          beforeTime = DateTime.Now;          Excel.Applicat

JS和jQuery获取节点的兄弟,父级,子级元素

原文转自http://blog.csdn.net/duanshuyong/article/details/7562423 先说一下JS的获取方法,其要比JQUERY的方法麻烦很多,后面以JQUERY的方法作对比。 JS的方法会比JQUERY麻烦很多,主要则是因为FF浏览器,FF浏览器会把你的换行也当最DOM元素。 <div id="test"><div></div><div></div

vcpkg子包路径批量获取

获取vcpkg 子包的路径,并拼接为set(CMAKE_PREFIX_PATH “拼接路径” ) import osdef find_directories_with_subdirs(root_dir):# 构建根目录下的 "packages" 文件夹路径root_packages_dir = os.path.join(root_dir, "packages")# 如果 "packages"

struts2中的json返回指定的多个参数

要返回指定的多个参数,就必须在struts.xml中的配置如下: <action name="goodsType_*" class="goodsTypeAction" method="{1}"> <!-- 查询商品类别信息==分页 --> <result type="json" name="goodsType_findPgae"> <!--在这一行进行指定,其中lis是一个List集合,但

Weex入门教程之4,获取当前全局环境变量和配置信息(屏幕高度、宽度等)

$getConfig() 获取当前全局环境变量和配置信息。 Returns: config (object): 配置对象;bundleUrl (string): bundle 的 url;debug (boolean): 是否是调试模式;env (object): 环境对象; weexVersion (string): Weex sdk 版本;appName (string): 应用名字;

Collection的所有的方法演示

import java.util.ArrayList;import java.util.Collection;import java.util.Iterator;public class TestCollection {/*** @param args* Collection的所有的方法演示* 此程序没有使用泛型,所以可以添加任意类型* 以后如果写到泛型会补充这一方面的内容*/public s

Temu官方宣导务必将所有的点位材料进行检测-RSL资质检测

关于饰品类产品合规问题宣导: 产品法规RSL要求 RSL测试是根据REACH法规及附录17的要求进行测试。REACH法规是欧洲一项重要的法规,其中包含许多对化学物质进行限制的规定和高度关注物质。 为了确保珠宝首饰的安全性,欧盟REACH法规规定,珠宝首饰上架各大电商平台前必须进行RSLReport(欧盟禁限用化学物质检测报告)资质认证,以确保产品不含对人体有害的化学物质。 RSL-铅,