什么是抽象工厂模式
这篇说说工厂的最后一种,还是先上
抽象工厂模式定义(来自百度百科):
抽象工厂模式是所有形态的工厂模式中最为抽象和最具一般性的一种形态。抽象工厂模式是指当有多个抽象角色时,使用的一种工厂模式。
抽象工厂模式可以向客户端提供一个接口,使客户端在不必指定产品的具体的情况下,创建多个产品族中的产品对象。根据里氏替换原则,
任何接受父类型的地方,都应当能够接受子类型。因此,实际上系统所需要的,仅仅是类型与这些抽象产品角色相同的一些实例,而不是这些抽象产品的实例。
换言之,也就是这些抽象产品的具体子类的实例。工厂类负责创建抽象产品的具体子类的实例。
UML 类图
具体代码:
public class Client {public static void main(String[] args) {// Creator benzCreator = new BenzCreator();// benzCreator.createCar().run();//// Creator bmwCreator = new BmwCreator();// bmwCreator.createCar().run();AbstractFactory factory1 = new Factory1(); factory1.createProductA().getProductAName(); factory1.createProductB().getProductBName(); AbstractFactory factory2 = new Factory2(); factory2.createProductA().getProductAName(); factory2.createProductB().getProductBName(); } }public interface AbstractFactory { AbstractProductA createProductA(); AbstractProductB createProductB(); }public class Factory1 implements AbstractFactory { @Overridepublic AbstractProductA createProductA() {return new ProductA1(); } @Overridepublic AbstractProductB createProductB() {return new ProductB1(); } }public class Factory2 implements AbstractFactory { @Overridepublic AbstractProductA createProductA() {return new ProductA2(); } @Overridepublic AbstractProductB createProductB() {return new ProductB2(); } }public interface AbstractProductA { String getProductAName(); }public class ProductA1 implements AbstractProductA { ProductA1(){ System.out.println("产品A1"); } @Overridepublic String getProductAName() {return "产品A1名称"; } }public class ProductA2 implements AbstractProductA { ProductA2(){ System.out.println("产品A2"); } @Overridepublic String getProductAName() {return "产品A2名称"; } }public interface AbstractProductB { String getProductBName(); }public class ProductB1 implements AbstractProductB { ProductB1(){ System.out.println("产品B1"); } @Overridepublic String getProductBName() {return "产品B1名称"; } }public class ProductB2 implements AbstractProductB { ProductB2(){ System.out.println("产品B2"); } @Overridepublic String getProductBName() {return "产品B2名称"; } }
产品族:
是指位于不同产品等级结构中,功能相关联的产品组成的家族
具体例子:
我举个可能不大恰当的例子
例如我们电脑都是 32和64位的 对应的机器安装对应位数的软件
两张光盘 分别存储32位和64位的软件 那装机的时候 只需要拿一张光盘就搞定的整机软件安装 不用挨个软件去找。
这里 光盘就是具体的工厂 如果每张光盘都有QQ和360(就是要打架 怎样?)
这里32位的光盘 就是上面代码里的Factory1 这里64位的光盘 就是上面代码里的Factory2
32位的光盘里的QQ就是ProductA1,360就是ProductB1
64位的光盘里的QQ就是ProductA2,360就是ProductB2
对于我这小白用户,拿对光盘就行了,不需要既找对QQ的位数又找到360的位数,是不是很爽。
优缺点
优点:
分离接口和实现,这样客户端不需要知道具体的实现。
产品族的切换变得容易,就像如果出现128位的机器,无非多加一张光盘。
缺点:
不容易扩展新产品(想象一下增加一个产品要加多少类和方法吧)。
类的层级结构复杂(看看类图都是想吐的有木有)
本质:
之前说过工厂方法的本质就是选择实现,就是选择具体的产品
那抽象工厂就是选择产品族,由单一产品变成产品族而已。
三种工厂模式说完了,他们之间的联系区别和演化过程就先挖个坑,之后再写。
以上是什么是抽象工厂模式的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

在Java框架中,设计模式和架构模式的区别在于:设计模式定义了在软件设计中解决常见问题的抽象解决方案,关注类和对象之间的交互,如工厂模式。架构模式定义了系统结构和模块之间的关系,关注系统组件的组织和交互,如分层架构。

装饰器模式是一种结构型设计模式,允许动态添加对象功能,无需修改原始类。它通过抽象组件、具体组件、抽象装饰器和具体装饰器的协作实现,可以灵活扩展类功能,满足变化的需求。示例中,将牛奶和摩卡装饰器添加到Espresso,总价为2.29美元,展示了装饰器模式在动态修改对象行为方面的强大功能。

适配器模式是一种结构型设计模式,允许不兼容对象协同工作,它将一个接口转换为另一个,使对象能够顺利交互。对象适配器通过创建包含被适配对象的适配器对象,并实现目标接口,实现适配器模式。在一个实战案例中,通过适配器模式,客户端(如MediaPlayer)可以播放高级格式的媒体(如VLC),尽管其本身仅支持普通媒体格式(如MP3)。

1.工厂模式:分离对象创建和业务逻辑,通过工厂类创建指定类型的对象。2.观察者模式:允许主题对象通知观察者对象其状态更改,实现松耦合和观察者模式。

TDD用于编写高质量PHP代码,步骤包括:编写测试用例,描述预期功能并使其失败。编写代码,仅使测试用例通过,无需过分优化或详细设计。测试用例通过后,优化和重构代码以提高可读性、可维护性和可扩展性。

设计模式通过提供可重用和可扩展的解决方案来解决代码维护难题:观察者模式:允许对象订阅事件,并在事件发生时收到通知。工厂模式:提供了一种创建对象的集中式方式,而无需依赖具体类。单例模式:确保一个类只有一个实例,用于创建全局可访问的对象。

Java框架中使用设计模式的优点包括:代码可读性、可维护性和可扩展性增强。缺点包括:过度使用导致复杂性、性能开销以及学习曲线陡峭。实战案例:代理模式用于延迟加载对象。明智地使用设计模式可充分利用其优势并最小化缺点。

Guice框架应用了多项设计模式,包括:单例模式:通过@Singleton注解确保类只有一个实例。工厂方法模式:通过@Provides注解创建工厂方法,在依赖注入时获取对象实例。策略模式:将算法封装成不同策略类,通过@Named注解指定具体策略。
