如何基于运行时生成的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()