创建型模式之Abstract Factory(抽象工厂)

创建型模式之Abstract Factory(抽象工厂)

摘要:

本文介绍了抽象工厂模式(Abstract Factory),它是一种创建型设计模式,提供了一种创建一系列相关对象的接口而无需指定具体类。文章通过手机工厂示例进行说明,展示小米和华为两个工厂分别生产不同类型产品(屏幕、芯片、键盘等)的实现过程。代码演示了如何定义抽象工厂接口、具体工厂类和产品类,并展示了运行结果。该模式适用于需要创建产品族且不依赖具体产品类的情况,能够提高系统的灵活性和可扩展性。

前言

创建型

1.简单工厂 -->> 2.工厂方法 -->> 3.抽象工厂 -->> 4.生成器 -->> 5.原生 -->> 6.单例

1,接着23种设计模式,创建型模式的抽象工厂 开始讲解
2,用自己的话理解是:抽象工厂【是生产一类产品或一系列相关的工厂,不需要指定具体的类】,比如手机工厂:小米手机工厂、华为手机工厂、OPPO手机工厂...

1)意图

提供一个创建一系列相关或相互依赖对象的接口,而无须指定它们具体的类。

2)结构

代码如下:

c 复制代码
/**
 * 抽象工厂demo
 */
public class AbstractFactory {

    public static void main(String[] args) {
        // 小米生产线 开始制造
        System.out.println("小米生产线 开始制造-------------------------");
        Factory factory1 = new ConcreteFactory1();
        factory1.createProductA().info();
        factory1.createProductB().info();

        System.out.println("------------------分界线----------------------");
        // 华为生产线 继续开始制造
        System.out.println("华为生产线 继续开始制造-------------------------");
        Factory factory2 = new ConcreteFactory2();
        factory2.createProductA().info();
        factory2.createProductB().info();
    }

}

interface Factory{
    // 小米手机生产线
    ProductA createProductA();
    // 华为电脑生产线
    ProductB createProductB();
}

/**
 * 华为电脑工厂
 */
class ConcreteFactory2 implements Factory{

    @Override
    public ProductA createProductA() {
        return new ProductA2();
    }

    @Override
    public ProductB createProductB() {
        return new ProductB2();
    }
}

/**
 * 小米手机工厂
 */
class ConcreteFactory1 implements Factory{

    @Override
    public ProductA createProductA() {
        return new ProductA1();
    }

    @Override
    public ProductB createProductB() {
        return new ProductB1();
    }
}

/**
 * 为一类产品声明一个接口 比如小米手机生产线
 */
interface ProductA{
    void info();
}

/**
 * 为另一类产品声明一个接口 比如华为手机生产线
 */
interface ProductB{
    void info();
}


class ProductB2 implements ProductB{
    @Override
    public void info() {
        System.out.println("产品 B2 华为电脑显示器");
    }
}

class ProductB1 implements ProductB{
    @Override
    public void info() {
        System.out.println("产品 B1 小米芯片");
    }
}

class ProductA1 implements ProductA{
    @Override
    public void info() {
        System.out.println("产品 A1 小米屏幕");
    }
}

class ProductA2 implements ProductA{
    @Override
    public void info() {
        System.out.println("产品 A2 华为笔记本键盘");
    }
}

运行结果:如下

喜欢我的文章记得点个在看,或者点赞,持续更新中ing...

相关推荐
但要及时清醒3 分钟前
ArrayList和LinkedList
java·开发语言
一叶飘零_sweeeet12 分钟前
从测试小白到高手:JUnit 5 核心注解 @BeforeEach 与 @AfterEach 的实战指南
java·junit
孚亭19 分钟前
Swift添加字体到项目中
开发语言·ios·swift
hweiyu0023 分钟前
Go、DevOps运维开发实战(视频教程)
开发语言·golang·运维开发
摇滚侠29 分钟前
Spring Boot3零基础教程,Reactive-Stream 四大核心组件,笔记106
java·spring boot·笔记
Z3r4y30 分钟前
【代码审计】RuoYi-3.0 三处安全问题分析
java·web安全·代码审计·ruoyi-3.0
mm-q291522272934 分钟前
Python+Requests零基础系统掌握接口自动化测试
开发语言·python
与遨游于天地1 小时前
Spring解决循环依赖实际就是用了个递归
java·后端·spring
陈果然DeepVersion1 小时前
Java大厂面试真题:Spring Boot+微服务+AI智能客服三轮技术拷问实录(六)
java·spring boot·redis·微服务·面试题·rag·ai智能客服