方法实例化抽象类的特定子类



如何基于运行时生成的classNameString创建抽象类的特定子类的对象?假设有一个抽象类A

public abstract class A {
    abstract protected void method();               
    A getNewInstance() throws InstantiationException, IllegalAccessException{
        return this.getClass().newInstance();
    }
}

设有N个子类即A1, A2,…,一个。需要编写以下方法,该方法将返回一个基于classNameString

的子类对象
A getSubClassObject(String classNameString)

我有以下两个丑陋的实现第一:

A getSubClassObject(String classNameString){
    A obj = null;
    if(classNameString.equals("A1")){
        obj = new A1();
    }else if(classNameString.equals("A2")){
        obj = new A2();         
    }
    ...
    }else if(classNameString.equals("AN")){
        obj = new AN();         
    }
    return obj;
}
第二:

A getSubClassObject(String classNameString){
    A obj = null;
    try {
       obj = this.subClassObjectsHashMap().get(classNameString).getNewInstance();
    } catch (InstantiationException e) {
       e.printStackTrace();
    } catch (IllegalAccessException e) {
       e.printStackTrace();
    }
    return obj;
}
private HashMap<String, A> subClassObjectsHashMap(){
    HashMap<String, A> subClassObjectsHashMap = new HashMap<String,A>();
    subClassObjectsHashMap.put("A1", new A1());
    subClassObjectsHashMap.put("A2", new A2());
    ....
    subClassObjectsHashMap.put("AN", new AN());
    return subClassObjectsHashMap;
}

有更好的方法来解决这个问题吗?

不如像

return (A)Class.forName(runtimeClassName).newInstance();

有适当的错误处理吗?

是的,如果所有构造函数接收相同的参数(在您的示例中,没有参数),您可以执行

Class clazz = Class.forName("fully.qualified.class.nane");
A a = (A) clazz.newInstace();

两种方法都可能抛出各种异常,因此需要添加一些catch块。

查看Java API中的Java .lang. class,方法forName(String)和newInstance()

相关内容

  • 没有找到相关文章

最新更新