繁体   English   中英

如何动态投射 Java object

[英]How do I dynamically cast Java object

我有以下方法:

public static Category getImpl(Class<Category> category) throws IllegalAccessException, InstantiationException
{

        Reflections reflections = new Reflections("com.dpd.modules");
        Set<Class<? extends Category>> classes = reflections.getSubTypesOf(category);


        Category queryGetter = null;

        if (DDLTool.isOracle())
        {
            for (Class s : classes)
            {
                if (Oracle.class.isAssignableFrom(s))
                {
                    queryGetter =  s.newInstance();
                }
            }

        }
        else if (DDLTool.isMSSQL())
        {
            for (Class s : classes)
            {
                if (MsSql.class.isAssignableFrom(s))
                {
                    queryGetter = s.newInstance();
                }
            }
        }
        else if (DDLTool.isPostgres())
        {
            for (Class s : classes)
            {
                if (PosgtreSql.class.isAssignableFrom(s))
                {
                    queryGetter = s.newInstance();
                }
            }
        }

        return queryGetter;

 }

但是,我不能真正将 queryGetter 转换为所需的类别

inheritance 树如下所示:

Category (Interface) -> PortalCorp extends Category (Interface) | Portal365 extends Category (Interface) 

Oracle | MsSql | PosgtreSql (all Interfaces)

然后是具体的类(仅适用于 PortalCorp,Portal365 也是如此):

MsSqlQueryGetterPortalCorp implements PortalCorp, MsSql

OracleQueryGetterPortalCorp implements PortalCorp, Oracle

PostgresQueryGetterPortalCorp implements PortalCorp, PosgtreSql

但是我在线上遇到不兼容的类型错误:

queryGetter = s.newInstance();

我如何以这样的方式实现所需的行为,如果我执行

 getImpl(PortalCorp.class); 

并且DDLTool.isOracle()返回 true

我最终会得到com.dpd.modules.OracleQueryGetterPortalCorp的实例吗?

提前致谢

循环变量未使用 generics。 如果您尝试:

for (Class<? extends Category> s : classes)

如果编译器也不喜欢这样,那么在分配新实例之前如何转换它:

queryGetter = (Category) s.newInstance();

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM