这是我的抽象类
public abstract class AbstractActionModel implements IActionModel{
public abstract void getModel();
public abstract void getAction();
}
然后,我想像下面这样使用这个抽象类:
this.getActions().put("sth", AbstractActionModel.builder().action("sth").build());
由于我无法实例化一个抽象类,因此构建器模式将无法工作,我也不知道有其他替代模式可以执行此操作。
注意:我也不了解从该基类扩展的类。
如果您想在不了解具体子类的情况下编写生成器,则代码的调用者将必须提供有关要创建哪个子类的信息-通过提供实际的类对象或使用名称注册一组类。例如:
public class Builders
{
public static abstract class AbstractActionModel
{
public abstract void getModel();
public abstract void getAction();
public abstract void setAction(String action);
}
public static class ConcreteActionModel extends AbstractActionModel
{
public void getModel() {};
public void getAction() {};
public void setAction(String action) {};
}
public static class ModelBuilder
{
AbstractActionModel model;
Map<String, Class<? extends AbstractActionModel>> register = new HashMap<String, Class<? extends AbstractActionModel>>();
public void register(String key, Class<? extends AbstractActionModel> c) {register.put("concrete", ConcreteActionModel.class);}
public ModelBuilder choose(String key) throws InstantiationException, IllegalAccessException {
model = register.get(key).newInstance();
return this;
}
public ModelBuilder action(String action) {
model.setAction(action);
return this;
}
public AbstractActionModel build() {
return model;
}
}
public static void main(String[] args) throws Exception
{
ModelBuilder mb = new ModelBuilder();
mb.register("concrete", ConcreteActionModel.class);
mb.choose("concrete").action("sth").build();
}
}
请注意,抽象类将需要添加setter方法,以便构建器可以在不了解具体子类的情况下更新属性。
另外,您可以使用反射来检查子类并调用其方法。
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句