使用抽象工厂模式一般要满足以下条件。
系统中有多个产品族,每个具体工厂创建同一族但属于不同等级结构的产品。
系统一次只可能消费其中某一族产品,即同族的产品一起使用
抽象工厂模式除了具有工厂方法模式的优点外,其他主要优点如下。
可以在类的内部对产品族中相关联的多等级产品共同管理,而不必专门引入多个新的类来进行管理。
当增加一个新的产品族时不需要修改原代码,满足开闭原则。
其缺点是:当产品族中需要增加一个新的产品时,所有的工厂类都需要进行修改。
以生产电脑为例子:
当涉及到这种产品族的问题的时候,就需要抽象工厂模式来支持了。我们不再定义 CPU 工厂、主板工厂、硬盘工厂、显示屏工厂等等,我们直接定义电脑工厂,每个电脑工厂负责生产所有的设备,这样能保证肯定不存在兼容问题。
public interface ComputerFactory {
CPU makeCPU();
MainBoard makeMainBoard();
}
public class IntelFactory implements ComputerFactory{
@Override
public CPU makeCPU() {
return new InelCPU();
}
@Override
public MainBoard makeMainBoard() {
return new IntelMainBoard();
}
}
public class AMDFactory implements ComputerFactory {
@Override
public AMDCPU makeCPU() {
return new AMDCPU();
}
@Override
public AMDMainBoard makeMainBoard() {
return new AMDMainBoard();
}
}
public class CPU {
public String getName(){
return "";
}
}
public class InelCPU extends CPU {
public String getName(String name){
return "intel";
}
}
public class AMDCPU extends CPU {
AMDCPU(){
System.out.println("做一个amd的cpu");
}
public String getName(){
return "amd";
}
}
public class IntelMainBoard extends MainBoard {
public String getName(){
return "intel";
}
}
public class MainBoard {
public String getName(){
return "";
}
}
public class AMDMainBoard extends MainBoard {
AMDMainBoard(){
System.out.println("做一个amd的主板");
}
public String getName(){
return "amd";
}
}
public class Computer {
public Computer(CPU cpu,MainBoard mainBoard){
System.out.println("将"+cpu.getName()+"牌的cpu,加上"+mainBoard.getName()+"牌子的主板整合");
}
}
public class TestFactory {
public static void main(String[] args) {
// 第一步就要选定一个“大厂”
ComputerFactory cf = new AMDFactory();
// 从这个大厂造 CPU
CPU cpu = cf.makeCPU();
// 从这个大厂造主板
MainBoard board = cf.makeMainBoard();
// 将同一个厂子出来的 CPU、主板组装在一起
Computer result = new Computer(cpu, board);
}
}