工厂模式是一种比较常见的创建型设计模式,分为简单工厂模式、工厂方法模式、抽象工厂模式
工厂模式旨在把对象的创建和使用分离开来,把创建对象的职责交给工厂类,这样会有哪些好处?
解耦:对象的创建和使用分离
减少代码重复、创建蔓延,降低维护成本:对于创建较为复杂的对象,可以减少代码重复、降低维护成本
简单工厂方法并不属于23种常见设计模式之一,适用于相对简单的场景,创建较少的对象。最重要的一点是它违背了开闭原则(对扩展开发,对修改关闭)(可以通过反射机制避免),因为在扩展产品类的时候需要添加条件分支(如if-else、switch-case),需要修改工厂类方法
简单工厂模式角色分配
创建一个可以展示不同图表的工具,可以展示柱状图、饼图、折线图,每个图表对象都有方法display()
展示图表。
简单工厂
public class ChartFactory {
/**
* 创建图表 负担太重、不符合开闭原则
*/
public static IChart create(String type) {
switch (type) {
case "bar":
return new BarChart();
case "pie":
return new PieChart();
case "line":
return new LineChart();
default:
return null;
}
}
}
静态方法工厂
public class ChartFactory2 {
public static BarChart createBarChart() {
return new BarChart();
}
public static PieChart createPieChart() {
return new PieChart();
}
public static LineChart createLineChart() {
return new LineChart();
}
}
使用简单工厂模式,当我们需要扩展的时候,是不符合开闭原则的,如上面的例子需要多一种图表展示,那么工厂类的创建方法就需要多处理一个条件分支。那如何可以让我们对扩展开放、对修改关闭呢?使用反射机制是可以做到的
public class ChartFactory3 {
public static IChart create(Class<? extends IChart> clazz) {
IChart chart = null;
try {
chart = clazz.newInstance();
} catch (InstantiationException | IllegalAccessException e) {
e.printStackTrace();
}
return chart;
}
public static IChart create(String className) {
IChart chart = null;
try {
chart = (IChart) Class.forName(className).newInstance();
} catch (InstantiationException | IllegalAccessException | ClassNotFoundException e) {
e.printStackTrace();
}
return chart;
}
}
Spring 的Ioc容器是通过配置文件和反射机制解决了简单工厂中的缺点
工厂方法的使用频率很高,经常可以在一些项目中看见
工厂方法(Factory Method) - 定义一个用于创建对象的接口,让子类决定实例化哪一个类。工厂方法使一个类的实例化延迟到其子类
工厂方法针对每一种产品提供一个工厂类,通过不同的工厂实例来创建不同的产品实例,相比于简单工厂来说,不再提供一个统一的工厂创建所有的对象
优点
缺点
工厂方法模式角色分配
对上面简单工厂模式的例子修改,增加一个工厂接口和实现接口的具体工厂类
工厂接口
public interface IChartFactory {
IChart getChart();
}
工厂实现-柱状图工厂类
public class BarChartFactory implements IChartFactory{
@Override
public IChart getChart() {
return new BarChart();
}
}
抽象工厂模式是比较难理解的工厂模式了,它的定义如下
抽象工厂模式(Abstract Factory) - 为创建一组相关或相互依赖的对象提供一个接口,而且无须指定它们的具体类
抽象工厂模式角色分配
如上类图,ProductA
和ProductB
是一个产品族的两个抽象产品,两个抽象产品都各自有可能有多个实现,ConcreteProductA1、ConcreteProductA2、ConcreteProductB1、ConcreteProductB2都是这些抽象产品的具体实现。AbstractFactory
是工厂类的抽象接口,包含所有产品创建的抽象方法,工厂类不止是去创建一个产品对象,而是负责创建一个产品族的对象
有组装过台式电脑的人可能知道一台电脑有很多配件组成,有CPU、主板、显卡、内存、硬盘、外设等,这些配件就可以看成是一个产品族的产品,而各个配件有不同的生产厂家和型号,有的可以混合搭配、有的需要指定型号。这里为了简单,假设只需要CPU和主板,CPU的生产厂家主要是Intel和AMD、对应的主板型号也不尽相同
抽象工厂
public interface IFactory {
ICpu createCpu();
IMainboard createMainboard();
}
抽象产品
public interface ICpu {
void installCpu();
}
public interface IMainboard {
void installMainboard();
}
工厂模式区别
因篇幅问题不能全部显示,请点此查看更多更全内容