抽象工厂模式(Java与Kotlin版)
前文推送
设计模式
Kotlin基础知识
1. 定义
抽象工厂模式(Abstract Factory Pattern):提供一个创建一系列相关或相互依赖对象的接口,而无须指定它们具体的类。抽象工厂模式又称为Kit模式,属于对象创建型模式。
2. 结构
AbstractFactory:抽象工厂,定义创建实例的抽象方法;
ConcreteFactory:具体工厂,实现具体逻辑;
AbstractProduct:抽象产品,定义产品的抽象方法;
Product:具体产品,实现具体逻辑;
3. 代码
3.1 Java
AbstractProductA与AbstractProductB:
abstract class AbstractProductA {
abstract void printA();
}
abstract class AbstractProductB {
abstract void printB();
}
定义了两个抽象产品角色,分别有抽象方法printA和printB。
ConcreteProductA1、ConcreteProductA2、ConcreteProductB1及ConcreteProductB2:
class ConcreteProductA1 extends AbstractProductA {
void printA() {
System.out.println("printA of ConcreteProductA1");
}
}
class ConcreteProductA2 extends AbstractProductA {
void printA() {
System.out.println("printA of ConcreteProductA2");
}
}
class ConcreteProductB1 extends AbstractProductB {
void printB() {
System.out.println("printB of ConcreteProductB1");
}
}
class ConcreteProductB2 extends AbstractProductB {
void printB() {
System.out.println("printB of ConcreteProductB2");
}
}
定义了四个具体产品角色,分别实现了父类对应的printA和printB方法。
A1和B1属于同一个产品族的不同产品等级的两种产品,A2和B2类似。其中:
产品等级——同一类产品的产品等级相同,如海尔冰箱、西门子冰箱等;
产品族——同一家工厂生产的不同产品等级的产品,如海尔冰箱、海尔洗衣机等。
AbstractFactory:
abstract class AbstractFactory {
abstract AbstractProductA createProductA();
abstract AbstractProductB createProductB();
}
定义了抽象工厂角色,及抽象方法createProductA和createProductB。
ConcreteFactory1与ConcreteFactory2:
class ConcreteFactory1 extends AbstractFactory {
AbstractProductA createProductA() {
System.out.println("create ProductA1");
return new ConcreteProductA1();
}
AbstractProductB createProductB() {
System.out.println("create ProductB1");
return new ConcreteProductB1();
}
}
class ConcreteFactory2 extends AbstractFactory {
AbstractProductA createProductA() {
System.out.println("create ProductA2");
return new ConcreteProductA2();
}
AbstractProductB createProductB() {
System.out.println("create ProductB2");
return new ConcreteProductB2();
}
}
定义了两个具体工厂角色,分别实现了createProductA和createProductB方法。
AbstractFactoryPattern:
public class AbstractFactoryPattern {
public static void main(String[] args) {
System.out.println("Abstract Factory Pattern");
AbstractFactory factory = new ConcreteFactory1();
AbstractProductA productA = factory.createProductA();
AbstractProductB productB = factory.createProductB();
productA.printA();
productB.printB();
factory = new ConcreteFactory2();
productA = factory.createProductA();
productB = factory.createProductB();
productA.printA();
productB.printB();
}
}
不同产品族的具体产品实例,用不同的具体工厂来创建。
输出:

3.2 Kotlin
AbstractProductA与AbstractProductB:
abstract class AbstractProductA {
abstract fun printA()
}
abstract class AbstractProductB {
abstract fun printB()
}
ConcreteProductA1、ConcreteProductA2、ConcreteProductB1及ConcreteProductB2:
class ConcreteProductA1 : AbstractProductA() {
override fun printA() {
println("printA of ConcreteProductA1")
}
}
class ConcreteProductA2 : AbstractProductA() {
override fun printA() {
println("printA of ConcreteProductA2")
}
}
class ConcreteProductB1 : AbstractProductB() {
override fun printB() {
println("printB of ConcreteProductB1")
}
}
class ConcreteProductB2 : AbstractProductB() {
override fun printB() {
println("printB of ConcreteProductB2")
}
}
AbstractFactory:
abstract class AbstractFactory {
abstract fun createProductA(): AbstractProductA
abstract fun createProductB(): AbstractProductB
}
ConcreteFactory1与ConcreteFactory2:
class ConcreteFactory1 : AbstractFactory() {
override fun createProductA(): AbstractProductA {
println("create ProductA1")
return ConcreteProductA1()
}
override fun createProductB(): AbstractProductB {
println("create ProductB1")
return ConcreteProductB1()
}
}
class ConcreteFactory2 : AbstractFactory() {
override fun createProductA(): AbstractProductA {
println("create ProductA2")
return ConcreteProductA2()
}
override fun createProductB(): AbstractProductB {
println("create ProductB2")
return ConcreteProductB2()
}
}
AbstractFactoryPattern:
fun main(args: Array<String>) {
println("Abstract Factory Pattern")
var factory: AbstractFactory = ConcreteFactory1()
var productA = factory.createProductA()
var productB = factory.createProductB()
productA.printA()
productB.printB()
factory = ConcreteFactory2()
productA = factory.createProductA()
productB = factory.createProductB()
productA.printA()
productB.printB()
}
输出同上。
4. 优缺点
4.1 优点
抽象工厂模式隔离了具体类的生成,使得客户并不需要知道什么被创建。由于这种隔离,更换一个具体工厂就变得相对容易。所有的具体工厂都实现了抽象工厂中定义的那些公共接口,因此只需改变具体工厂的实例,就可以在某种程度上改变整个软件系统的行为。另外,应用抽象工厂模式可以实现高内聚低耦合的设计目的,因此抽象工厂模式得到了广泛的应用;
当一个产品族中的多个对象被设计成一起工作时,它能够保证客户端始终只使用同一个产品族中的对象。这对一些需要根据当前环境来决定其行为的软件系统来说,是一种非常实用的设计模式;
增加新的具体工厂和产品族很方便,无须修改已有系统,符合“开闭原则”。
4.2 缺点
在添加新的产品对象时,难以扩展抽象工厂来生产新种类的产品,这是因为在抽象工厂角色中规定了所有可能被创建的产品集合,要支持新种类的产品就意味着要对该接口进行扩展,而这将涉及到对抽象工厂角色及其所有子类的修改,显然会带来较大的不便;
开闭原则的倾斜性(增加新的工厂和产品族容易,增加新的产品等级结构麻烦)。
5. 适用场景
一个系统不应当依赖于产品类实例如何被创建、组合和表达的细节,这对于所有类型的工厂模式都是重要的;
系统中有多于一个的产品族,而每次只使用其中某一产品族;
属于同一个产品族的产品将在一起使用,这一约束必须在系统的设计中体现出来;
系统提供一个产品类的库,所有的产品以同样的接口出现,从而使客户端不依赖于具体实现。
抽象工厂模式(Java与Kotlin版)的更多相关文章
- 设计模式之第2章-抽象工厂模式(Java实现)
设计模式之第2章-抽象工厂模式(Java实现) “上次是我的不对,贿赂作者让我先讲来着,不过老婆大人大人有大量,不与我计较,这次还让我先把上次未讲完的应用场景部分给补充上去,有妻如此,夫复何求.”(说 ...
- 抽象工厂模式(JAVA反射)
实例代码(JAVA):模式动机 在工厂方法模式中具体工厂负责生产具体的产品,每一个具体工厂对应一种具体产品,工厂方法也具有唯一性,一般情况下,一个具体工厂中只有一个工厂方法或者一组重载的工厂方 ...
- 抽象工厂模式--java代码实现
抽象工厂模式 抽象工厂模式,对方法工厂模式进行抽象.世界各地都有自己的水果园,我们将这些水果园抽象为一个水果园接口,在中国.英国和美国都有水果园,种植不同的水果,比如苹果.香蕉和梨等.这里将苹果进行抽 ...
- 设计模式之抽象工厂模式(Java实现)
“上次是我的不对,贿赂作者让我先讲来着,不过老婆大人大人有大量,不与我计较,这次还让我先把上次未讲完的应用场景部分给补充上去,有妻如此,夫复何求.”(说完,摸了摸跪的发疼的膝盖,咳咳,我发四我没笑!真 ...
- AbstractFactoryPattern(抽象工厂模式)-----Java/.Net
抽象工厂模式(Abstract Factory Pattern)是围绕一个超级工厂创建其他工厂.该超级工厂又称为其他工厂的工厂.
- Java设计模式(三) 抽象工厂模式
原创文章,同步发自作者个人博客,转载请注明出处 http://www.jasongj.com/design_pattern/abstract_factory/ 抽象工厂模式解决的问题 上文<工厂 ...
- 工厂方法模式(Java与Kotlin版)
前文推送 设计模式 简单工厂模式(Java与Kotlin版) Kotlin基础知识 Kotlin入门第一课:从对比Java开始 Kotlin入门第二课:集合操作 Kotlin入门第三课:数据类型 初次 ...
- 建造者模式(Java与Kotlin版)
前文推送 设计模式 简单工厂模式(Java与Kotlin版) 工厂方法模式(Java与Kotlin版) 抽象工厂模式(Java与Kotlin版) Kotlin基础知识 Kotlin入门第一课:从对比J ...
- JAVA设计模式--抽象工厂模式
抽象工厂设计模式 1.系统中有多个产品族,而系统一次只可能消费其中一族产品2.同属于同一个产品族的产品以其使用.来看看抽象工厂模式的各个角色(和工厂方法的如出一辙):抽象工厂角色: 这是工厂方法模式的 ...
随机推荐
- Windows8.1 + Nvidia cuda8.0 + Vs2015
操作系统:Windows8.1 显卡:Nivida GTX965M 开发工具:Vs2015 1.查看本机配置,查看显卡类型是否支持NVIDIA GPU选中计算机-->右键属性-->设备管理 ...
- OpenCV探索之路(八):重映射与仿射变换
重映射 重映射就是把一幅图像中某个位置的像素放置到另一个图片中指定位置的过程. 用一个数学公式来表示就是: 其中的 f 就是映射方式,也就说,像素点在另一个图像中的位置是由 f 来计算的. 在Open ...
- struts2.1.6教程六、使用标签
1.基础表单标签 准备工作:建立struts2tag项目,搭建好struts2的开发环境.在html我们常用的基础表单标签主要有文本域.密码域.提交.重置四种.它们在strust2中可以通过标签来生成 ...
- Java编程之反射中的注解详解
"注解"这个词,可谓是在Java编程中出镜率比较高,而且也是一个老生常谈的话题.我们之前在聊Spring相关的东西时,注解是无处不在,之前我们简单的聊过一些"注解&quo ...
- Linux网络原理及基础设,yum管理RPM包
一:ifconfig命令 1,ifconfig命令的功能:显示所有正在启动的网卡的详细信息或设定系统中网卡的IP地址. 2. 使用ifup和ifdown命令启动和停止网卡(详见linux系统管理P42 ...
- (转)wxWidgets 2.9.2svn(3.x)最小体积编译方法
官方论坛.网上记录的wxWidgets编译方法,会导致编译后的程序库非常大,原因在于对编译的方法选择不当.下面简单总结一下如何编译最新的SVN代码.下载最新源码(每日构建):http://biolpc ...
- Javascript加载执行顺序
本文主要内容 一.不同位置的script标签执行顺序 二.document.ready和window.onload的区别 一.不同位置的script标签执行顺序 整个加载的过程从解析头部开始,比如ht ...
- DOS学习札记(一)
DOS学习入门 最近碰到几个关于cmd命令操作,感觉操作快捷方便(也许是偶尔新鲜感使然),由于重装系统后,系统的资源管理器与功能分布都有一些不同,导致在寻找一些windows功能时有些费劲,比如说关闭 ...
- Vue单文件组件基础模板
背景 相信大家在使用Vue开发项目时,基本都是以单文件组件的形式开发组件的,这种方式好处多多: 1.代码集中,便于开发.管理和维护 2.可复用性高,直接将vue文件拷贝到新项目中 我暂时就想到这两点, ...
- linux--centos服务器配置
配置Centos服务器 1. 安装centos 安装时注意分区留下一个/data区给网站内容存储. 2. 配置网络连接 默认centos网络连接不是开机启动的,需要配置. vi /etc/sysc ...