一、概述
抽象工厂模式是指当有多个抽象角色时,使用的一种工厂模式。抽象工厂模式可以向客户端提供一个接口,使客户端在不必指定产品的具体情况下,创建多个产品族中的产品对象。
UML图:
其他的过多概念不再这里赘述,不如通过例子来实际感受与体会
二、实践
关键是搞清等级族的概念,这里以生产手机为例,假设生产小米5和小米6两个型号的手机,两个手机都有内存和处理器,但是内存和处理器的组合不同
:米5采用的是骁龙820+16G内存组合,而米6则是骁龙835+32G组合。生产对应产品的时候就会匹配对应的产品部件组合,不会出现米5的骁龙835+16G等
的配置。
看问题的角度也要发生变化,比如耐克有男鞋女鞋,乔丹有男鞋女鞋,可以按照品牌分为耐克、乔丹;也可以按照性别分为男鞋、女鞋。
抽象工厂(生产内存和处理器,由纵向改为了横向)
/**
* 抽象工厂
* 作者: Administrator
* 日期: 2017/10/26
**/
public interface AbstractFactory {
Memory createMemory();
Processor createProcessor();
}
抽象产品1(内存)
/**
* 内存接口
* 作者: Administrator
* 日期: 2017/10/26
**/
public interface Memory {
}
具体产品1。1(16G内存)
/**
* 16G内存
* 作者: Administrator
* 日期: 2017/10/26
**/
public class Memory16 implements Memory{
public Memory16() {
System.out.println("16GB内存");
}
}
具体产品1.2(32G内存)
/**
* 32G内存
* 作者: Administrator
* 日期: 2017/10/26
**/
public class Memory32 implements Memory{
public Memory32() {
System.out.println("32GB内存");
}
}
抽象产品2(处理器)
/**
* 处理器接口
* 作者: Administrator
* 日期: 2017/10/26
**/
public interface Processor {
}
具体产品2.1(820处理器)
/**
* 骁龙820
* 作者: Administrator
* 日期: 2017/10/26
**/
public class Processor820 implements Processor{
public Processor820() {
System.out.println("骁龙820");
}
}
具体产品2.2(835处理器)
/**
* 骁龙835
* 作者: Administrator
* 日期: 2017/10/26
**/
public class Processor835 implements Processor{
public Processor835() {
System.out.println("骁龙835");
}
}
具体工厂类1(生产米5,自动匹配配置)
/**
* 小米5的工厂
* 作者: Administrator
* 日期: 2017/10/26
**/
public class Mi5Factory implements AbstractFactory{
@Override
public Memory createMemory() {
return new Memory16();
}
@Override
public Processor createProcessor() {
return new Processor820();
}
}
具体工厂类2(生产米6,自动匹配配置)
/**
* 米6的工厂
* 作者: Administrator
* 日期: 2017/10/26
**/
public class Mi6Factory implements AbstractFactory{
@Override
public Memory createMemory() {
return new Memory32();
}
@Override
public Processor createProcessor() {
return new Processor835();
}
}
客户端的使用:
/**
* 客户端
* 作者: Administrator
* 日期: 2017/10/26
**/
public class Client {
public static void main(String[] args) {
Mi5Factory mi5Factory = new Mi5Factory();
mi5Factory.createMemory();
mi5Factory.createProcessor();
Mi6Factory mi6Factory = new Mi6Factory();
mi6Factory.createMemory();
mi6Factory.createProcessor();
}
}
三、改进与思考
对开闭原则的支持
以上述例子为例,需要增加新的配置组合,比如增加骁龙835+16G的组合(增加产品族),则符合开闭原则,只是拓展,无需修改
而如果需要增加一个新的产品等级结构(比如增加双摄),则所有工厂都需要改变;故抽象工厂模式部分支持开闭原则!
如知乎网友所说:
四、工厂模式小结
学习设计模式,很重要的一点是为什么要用这个设计模式,哪些地方要用这个设计模式。我们先来看来自百度知道的网友的提问:
我们看最佳答案怎么说的:
这里面的重点单词是:解耦!
还有一个很重要的一点是前面的六大原则的基本原则——“开闭原则”,尽量不要改老代码,而是添代码!
综上:
工厂模式可以隐藏创建的细节,隐藏了具体类名后续如果想换掉不会影响调用者
归一化的修改
调用者不关心创建细节,只针对接口编程(依赖抽象而非依赖具体)