抽象工厂模式(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.同属于同一个产品族的产品以其使用.来看看抽象工厂模式的各个角色(和工厂方法的如出一辙):抽象工厂角色: 这是工厂方法模式的 ...
随机推荐
- C#中设置TextBox控件中仅可以输入数字且设置上限
首先设置只可以输入数字: 首先设置TextBox控件的KeyPress事件:当用户按下的键盘的键不在数字位的话,就禁止输入 private void textBox1_KeyPress(object ...
- Hibernate乐观锁、悲观锁和多态
乐观锁和悲观锁 悲观锁(Pessimistic Lock), 顾名思义,就是很悲观,每次去拿数据的时候都认为别人会修改,所以每次在拿数据的时候都会上锁,这样别人想拿这个数据就会block直到它拿到锁 ...
- 使用Html5下WebSocket搭建简易聊天室
一.Html5WebSocket介绍 WebSocket protocol 是HTML5一种新的协议(protocol).它是实现了浏览器与服务器全双工通信(full-duplex). 现在,很多网站 ...
- struts2.1.6教程五、拦截器
在前面我们已经初步使用过拦截器,下面继续细细探讨. 1.概述strust2中的拦截器 拦截器是Struts2框架的核心,它主要完成解析请求参数.将请求参数赋值给Action属性.执行数据校验.文件上传 ...
- python连接sql server数据库实现增删改查
简述 python连接微软的sql server数据库用的第三方模块叫做pymssql(document:http://www.pymssql.org/en/stable/index.html).在官 ...
- OpenStack命令 创建网络和路由管理
1.登陆用户 :tdy(前提条件创建了tdy用户) 编写登陆用户tdy用户 脚本文件 user-operc.sh user-operc.sh : 登陆用户tdy: $ source user-ope ...
- Oracle CDC简介及异步在线日志CDC部署示例
摘要 最近由于工作需要,花时间研究了一下Oracle CDC功能和LogMiner工具,希望能找到一种稳定.高效的技术来实现Oracle增量数据抽取功能.以下是个人的部分学习总结和部署实践. 1. O ...
- rownum基本用法
对于rownum来说它是oracle系统顺序分配为从查询返回的行的编号,返回的第一行分配的是1,第二行是2,依此类推,这个伪字段可以用于限制查询返回的总行数,且rownum不能以任何表的名称作为前缀. ...
- Js实现京东无延迟菜单效果(demo)
一个端午节,外面人山人海,又那么热,我认为宅在家里看看慕课网,充实自己来的实际... 这是一个js实现京东无延迟菜单效果,感觉很好,分享给大家... 1.开发基本的菜单结构 2.开发普通的二级菜单效果 ...
- Unity运动残影技能
残影实现: 1.List<DrawMesh> list,此list中包含某一帧动画模型网格.材质 2.每过一段时间就将运动物体的模型add到list中(优化:未实现,网格合并) 3.Lat ...