软件设计重构秘笈19式-18提取工厂类

45 阅读2分钟

软件设计重构秘笈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;
    }

}

总结

这个重构经常会在项目中使用,如果要创建的对象是一个,你可以采用简单工厂,但是这种方式还是会存在很多依赖,维护起来也比较不方便。 所以推荐使用工厂方法模式,把实例化延迟到子类。 如果你要创建一系列的对象,那么就推荐你使用抽象工厂模式,但是要注意不要过度设计,只要能满足不断变化的需求和给以后的维护和重构带来方便即可。