文中内容转载于C语言中文网
工厂模式的优缺点
优点:
- 用户只需要知道具体工厂的名称就可得到所要的产品,无须知道产品的具体创建过程。
- 灵活性增强,对于新产品的创建,只需多写一个相应的工厂类。
- 典型的解耦框架。高层模块只需要知道产品的抽象类,无须关心其他实现类,满足迪米特法则、依赖倒置原则和里氏替换原则。
缺点:
- 类的个数容易过多,增加复杂度
- 增加了系统的抽象性和理解难度
- 抽象产品只能生产一种产品,此弊端可使用抽象工厂模式解决。
应用场景:
- 客户只知道创建产品的工厂名,而不知道具体的产品名。如 TCL 电视工厂、海信电视工厂等。
- 创建对象的任务由多个具体子工厂中的某一个完成,而抽象工厂只提供创建产品的接口。
- 客户不关心创建产品的细节,只关心产品的品牌
1、简单工厂模式
简单工厂模式不属于23设计模式
实现方法:
简单工厂模式的主要角色如下:
- 简单工厂(SimpleFactory):是简单工厂模式的核心,负责实现创建所有实例的内部逻辑。工厂类的创建产品类的方法可以被外界直接调用,创建所需的产品对象。
- 抽象产品(Product):是简单工厂创建的所有对象的父类,负责描述所有实例共有的公共接口。
- 具体产品(ConcreteProduct):是简单工厂模式的创建目标。
例如:
public interface Car {
public void show();
}
public class BenCiCar implements Car {
@Override
public void show() {
System.out.println("奔驰汽车");
}
}
public class AudiCar implements Car {
@Override
public void show() {
System.out.println("奥迪汽车");
}
}
public class SimpleFactory {
private static SimpleFactory instance = new SimpleFactory();
private SimpleFactory() {
}
public static SimpleFactory getInstance() {
return instance;
}
public Car makeCar(int type) {
switch (type) {
case 1:
return new AudiCar();
case 2:
return new BenCiCar();
default:
break;
}
return null;
}
/**
* 通过反射动态创建对象 + 单例模式 + 简单工厂
*
* @param name
* @return
*/
public Car makeCar(String name) {
try {
Class<?> cls = Class.forName(name);
Constructor<?> con = cls.getConstructor();
Car car = (Car) con.newInstance();
return car;
} catch (ClassNotFoundException e) {
e.printStackTrace();
} catch (NoSuchMethodException e) {
e.printStackTrace();
} catch (IllegalAccessException e) {
e.printStackTrace();
} catch (InstantiationException e) {
e.printStackTrace();
} catch (InvocationTargetException e) {
e.printStackTrace();
}
return null;
}
}
总结:
简单工厂模式就是指一个抽象产品,多个具体产品,由一个大厂负责生产(用反射解决扩展困难)
2、工厂方法模式
优点:
- 用户只需要知道具体工厂的名称就可得到所要的产品,无须知道产品的具体创建过程。
- 灵活性增强,对于新产品的创建,只需多写一个相应的工厂类。
- 典型的解耦框架。高层模块只需要知道产品的抽象类,无须关心其他实现类,满足迪米特法则、依赖倒置原则和里氏替换原则。
缺点:
- 类的个数容易过多,增加复杂度
- 增加了系统的抽象性和理解难度
- 抽象产品只能生产一种产品,此弊端可使用抽象工厂模式解决。
应用场景:
- 客户只知道创建产品的工厂名,而不知道具体的产品名。如 TCL 电视工厂、海信电视工厂等。
- 创建对象的任务由多个具体子工厂中的某一个完成,而抽象工厂只提供创建产品的接口。
- 客户不关心创建产品的细节,只关心产品的品牌
模式的结构
工厂方法模式的主要角色如下。
- 抽象工厂(Abstract Factory):提供了创建产品的接口,调用者通过它访问具体工厂的工厂方法 newProduct() 来创建产品。
- 具体工厂(ConcreteFactory):主要是实现抽象工厂中的抽象方法,完成具体产品的创建。
- 抽象产品(Product):定义了产品的规范,描述了产品的主要特性和功能。
- 具体产品(ConcreteProduct):实现了抽象产品角色所定义的接口,由具体工厂来创建,它同具体工厂之间一一对应。
//抽象产品
public interface Car {
void show();
}
//抽象工厂
public interface CarFactory {
public Car makeCar();
}
//实例产品
public class BMWCar implements Car {
@Override
public void show() {
System.out.println("宝马汽车");
}
}
//实例工厂
public class BMWCarFactory implements CarFactory {
private static BMWCarFactory audiCar = new BMWCarFactory();
private BMWCarFactory() {
}
public static BMWCarFactory getInstance(){
return audiCar;
}
@Override
public Car makeCar() {
return new BMWCar();
}
}
总结:
工厂方法模式就是指一个抽象产品对应一个具体的产品,一个抽象工厂对应一个具体的工厂,所以产品若是很多,则需要的工厂也很多。抽象工厂则能解决此问题
3、抽象工厂模式
模式的定义与特点
- 抽象工厂(AbstractFactory)模式的定义:是一种为访问类提供一个创建一组相关或相互依赖对象的接口,且访问类无须指定所要产品的具体类就能得到同族的不同等级的产品的模式结构。
抽象工厂模式除了具有工厂方法模式的优点外,其他主要优点如下。
- 可以在类的内部对产品族中相关联的多等级产品共同管理,而不必专门引入多个新的类来进行管理。
- 当需要产品族时,抽象工厂可以保证客户端始终只使用同一个产品的产品组。
- 抽象工厂增强了程序的可扩展性,当增加一个新的产品族时,不需要修改原代码,满足开闭原则。
其缺点是:当产品族中需要增加一个新的产品时,所有的工厂类都需要进行修改。增加了系统的抽象性和理解难度。
模式的结构
抽象工厂模式的主要角色如下。
- 抽象工厂(Abstract Factory):提供了创建产品的接口,它包含多个创建产品的方法 newProduct(),可以创建多个不同等级的产品。
- 具体工厂(Concrete Factory):主要是实现抽象工厂中的多个抽象方法,完成具体产品的创建。
- 抽象产品(Product):定义了产品的规范,描述了产品的主要特性和功能,抽象工厂模式有多个抽象产品。
- 具体产品(ConcreteProduct):实现了抽象产品角色所定义的接口,由具体工厂来创建,它同具体工厂之间是多对一的关系。
//抽象产品
public interface Car {
void show();
}
//抽象产品
public interface Bicycle {
void show();
}
//抽象工厂
public interface Factory {
public Car makeCar();
public Bicycle makeBicycle();
}
//实例产品
public class BenCiCar implements Car {
@Override
public void show() {
System.out.println("奔驰汽车");
}
}
//实例产品
public class BenCiBicycle implements Bicycle {
@Override
public void show() {
System.out.println("奔驰自行车");
}
}
//实例工厂
public class BenCiFactory implements Factory {
private static BenCiFactory instance = new BenCiFactory();
private BenCiFactory() {
}
public static BenCiFactory getInstance(){
return instance;
}
@Override
public Car makeCar() {
return new BenCiCar();
}
@Override
public Bicycle makeBicycle() {
return new BenCiBicycle();
}
}
总结:
抽象工厂模式指的是一个产品对应一个实例产品,一个抽象工厂和一个具体的工厂生产所有的产品。