简单工厂、工厂方法、抽象工厂三个设计模式都带有工厂二字,它们的作用类似,都是用于生产产品对象。本文将介绍它们之间区别。
1、简单工厂模式
该模式下有一个工厂类,工厂类提供静态方法,静态方法根据入参的不同创建不同类的对象。这些对象都一个共同的基类,因此还需要有一个抽象产品类和一系列具体产品类。
该模式简单易实现,将创建与使用分开,实现了解耦,但是当添加新产品时就需要修改工厂类的逻辑,违背开放 - 关闭原则,而且产品过多时,也会造成该类复杂,另静态方法不能被继承和重写,也会造成工厂角色无法形成基于继承的等级结构。
抽象产品类,这里使用接口定义了产品类,也可以使用抽象类定义:
public interface Product {
public void show();
}
具体产品类:
//产品A
public class ProductA implements Product{
public void show(){
System.out.println("我是A");
}
}
//产品B
public class ProductB implements Product {
public void show(){
System.out.println("我是B");
}
}
工厂类:
public class SimpleFactory {
public static Product getProduct(String name){
if("A".equals(name)){
return new ProductA();
}
if("B".equals(name)){
return new ProductB();
}
return null;
}
}
2、工厂方法模式
工厂方法模式定义一个抽象工厂类,该类里面定义一个生产产品的抽象方法,具体生产什么产品由子类负责实现。与简单工厂类似,也需要有一个抽象产品类和一系列具体产品类。
工厂方法模式解决了简单工厂的缺点,比如符合开放-封闭原则,每个类只负责单一功能,但它增加了类的规模,产品多时会造成类爆炸,而且还会造成系统难以理解。
抽象工厂类:
public interface Factory {
public Product create();
}
具体工厂类:
public class FactoryA implements Factory{
public Product create(){
return new ProductA();
}
}
public class FactoryB implements Factory{
public Product create(){
return new ProductB();
}
}
产品类与简单工厂一样。
3、抽象工厂模式
当生产产品族的时候,前面两种设计模式就有点力不从心。
产品族是指一组相关或相互依赖产品,比如汽车的零部件,车轮、底盘、座椅,同一个汽车品牌的零部件共同组成一辆汽车,那么这个品牌的这些零部件就组成一个产品族。
当系统中有多个产品族,而且每次需要生产一个产品族下的所有产品,那么便可以使用抽象工厂模式。
相对于前面两种设计模式,抽象工厂更加强大。不过它也有一些缺点:
- 规定了所有可能被创建的产品集合,扩展新产品时比较困难,需要修改抽象工厂;
- 增加了系统的抽象性和理解难度。
抽象工厂类:
public interface Factory {
public Wheel createWheel();
public Chair createChair();
}
抽象产品族:
public interface Wheel {
public void show();
}
public interface Chair {
public void show();
}
具体产品族:
public class WheelBMW implements Wheel {
public void show(){
System.out.println("制造BMW车轮");
}
}
public class WheelAudi implements Wheel {
public void show(){
System.out.println("制造奥迪车轮");
}
}
public class ChairAudi implements Chair{
public void show(){
System.out.println("制造奥迪座椅");
}
}
public class ChairBMW implements Chair{
public void show(){
System.out.println("制造BMW座椅");
}
}
具体工厂类:
public class FactoryAudi implements Factory{
public Wheel createWheel(){
return new WheelAudi();
}
public Chair createChair(){
return new ChairAudi();
}
}
public class FactoryBMW implements Factory{
public Wheel createWheel(){
return new WheelBMW();
}
public Chair createChair(){
return new ChairBMW();
}
}