软件设计重构秘笈19式-18提取工厂类
概念
本文中的“提取工厂类”是指如果要创建的对象很多,则代码会变的很复杂。一种很好的方法就是提取工厂类。
意图
提取工厂类主要解决创建的对象很多的时候,代码会变的很复杂问题 一般来说我们需要在代码中设置一些对象,以便获得它们的状态,从而使用对象,所谓的设置通常来说就是创建对象的实例并调用对象的方法。 有时如果要创建的对象很多,则代码会变的很复杂。 这便是工厂模式发挥作用的情形。工厂模式的复杂应用是使用抽象工厂创建对象集,但我们在这里只是使用基本的工厂类创建对象的一个简单应用。 如下代码所示,newInstance方法包含创建类的整个逻辑,如果现在要创建的类比较多而且逻辑比较复杂的话(如根据不同条件创建对象,什么时候创建对象), 我们的newInstance方法逻辑会变得很大,同时代码也变得很难维护。所以我们就会采用提取工厂类的方式进行提炼。
案例
public class PoliceCarController {
public PoliceCar newInstance(int mileage, boolean serviceRequired){
PoliceCar policeCar = new PoliceCar();
policeCar.setMileage(mileage);
policeCar.setServiceRequired(serviceRequired);
return policeCar;
}
}
重构
那么重构后的代码如下,newInstance方法变得很简单了,指需要调用实现接IPoliceCarFactory 接口的PoliceCarFactory 类就可以返回对象, 这样就隔开了创建对象的逻辑,如果需求现在变为根据不同的条件创建不同的对象,什么时候创建对象等都变成了比较简单的事情, 在后期可以把对象都配置在XML里面,使用反射的方式实现IOC注入创建。
public interface IPoliceCarFactory {
PoliceCar newInstance(int mileage, boolean serviceRequired);
}
public class PoliceCarFactory implements IPoliceCarFactory {
@Override
public PoliceCar newInstance(int mileage, boolean serviceRequired) {
PoliceCar policeCar = new PoliceCar();
policeCar.setMileage(mileage);
policeCar.setServiceRequired(serviceRequired);
return policeCar;
}
}
public class PoliceCarController {
private IPoliceCarFactory policeCarFactory;
public PoliceCarController(IPoliceCarFactory policeCarFactory) {
this.policeCarFactory = new PoliceCarFactory();
}
public PoliceCar newInstance(int mileage, boolean serviceRequired){
PoliceCar policeCar = policeCarFactory.newInstance(mileage,serviceRequired);
return policeCar;
}
}
总结
这个重构经常会在项目中使用,如果要创建的对象是一个,你可以采用简单工厂,但是这种方式还是会存在很多依赖,维护起来也比较不方便。 所以推荐使用工厂方法模式,把实例化延迟到子类。 如果你要创建一系列的对象,那么就推荐你使用抽象工厂模式,但是要注意不要过度设计,只要能满足不断变化的需求和给以后的维护和重构带来方便即可。