如何根据运行时生成的classNameString创建抽象类的特定子类的对象?假设有一个抽象类A
public abstract class A {
abstract protected void method();
A getNewInstance() throws InstantiationException, IllegalAccessException{
return this.getClass().newInstance();
}
}
让N个子类别为A1,A2,..,AN。需要编写以下方法,该方法将返回基于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;
}
有没有更好的方法来解决这个问题?
答案 0 :(得分:4)
做什么比如
return (A)Class.forName(runtimeClassName).newInstance();
有适当的错误处理吗?
答案 1 :(得分:2)
是的,如果所有构造函数都接收到相同的参数(在您的示例中,没有参数),则可以执行
Class clazz = Class.forName("fully.qualified.class.nane");
A a = (A) clazz.newInstace();
两种方法都可以抛出各种异常,因此您需要添加一些catch块。
答案 2 :(得分:0)
查看Java API中的Java.lang.Class,方法forName(String)和newInstance()