设计模式-----------工厂模式之抽象工厂模式(创建型)

简介: 抽象工厂模式是一种创建型设计模式,它提供了一个接口用于创建一系列相关或相互依赖的对象,而无需指定具体类,从而增强了程序的可扩展性并确保客户端只使用同一产品族的产品。

1、抽象工厂模式定义

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

在这里插入图片描述

产品族:一个品牌下的商品。比如海尔企业下的:海尔电视、海尔空调、海尔洗衣机…

产品等级:同一个商品不同的企业生产。比如 海尔电视、格力电视、美的电视…

(理解:比如说,海尔电器这个企业可以生产、海尔电视机、海尔空调。格力这个企业可以生产海尔电视机、海尔空调。这个时候可以定义一个电视的抽象接口和空调的抽象接口。让每个企业生产的对应产品对应不同的抽象产品。然后再来一个格力工厂、专门生产格力企业下的产品。海尔工厂、专门生产海尔企业下的产品、、、)

2、应用场景

  • 需要生成产品族的情形

3、UML类图

在这里插入图片描述

4、抽象工厂模式的通用写法

package com.zheng;

public class Client {

    public static void main(String[] args) {
        //1、创建某一个企业的工厂
        IAbstractFactory factory = new contreteFactoryA();
        //2、工厂创建该企业下的商品并调用相应方法
        factory.createProduceA().dosome();
        factory.createProduceB().dislay();
    }


    //抽象工厂
    public interface IAbstractFactory {
        IabstractA createProduceA();

        IabstractB createProduceB();
    }


    //抽象产品
    public interface IabstractA {
        void dosome();
    }

    public interface IabstractB {
        void dislay();
    }


    //企业A下的产品
    static class ContreteProduceAWithFamilyA implements IabstractA {

        @Override
        public void dosome() {
            System.out.println("我是A企业下的具体产品A");
        }
    }

    static class ContreteProduceBWithFamilyA implements IabstractB {

        @Override
        public void dislay() {
            System.out.println("我是A企业下的具体产品B");
        }
    }

    //企业B下的产品

    static class ContreteProduceAWithFamilyB implements IabstractA {

        @Override
        public void dosome() {
            System.out.println("我是B企业下的具体产品A");
        }
    }

    static class ContreteProduceBWithFamilyB implements IabstractB {

        @Override
        public void dislay() {
            System.out.println("我是B企业下的具体产品B");
        }
    }

    //具体工厂A

    static class contreteFactoryA implements IAbstractFactory {

        @Override
        public IabstractA createProduceA() {
            return new ContreteProduceAWithFamilyA();
        }

        @Override
        public IabstractB createProduceB() {
            return new ContreteProduceBWithFamilyA();
        }
    }

    //具体工厂B
    static class contreteFactoryB implements IAbstractFactory {

        @Override
        public IabstractA createProduceA() {
            return new ContreteProduceAWithFamilyB();
        }

        @Override
        public IabstractB createProduceB() {
            return new ContreteProduceBWithFamilyB();
        }
    }


}

5、结果

在这里插入图片描述

6、举列子

java课程有录播的视频和笔记。

抽象工厂

package com.zheng.demo3;

public interface CourseFactory {
    INote cerateNote();
    IViedo cerateViedo();
}

抽象产品

抽象产品1,视频

package com.zheng.demo3;

public interface IViedo {
    void record();
}

抽象产品2,笔记

package com.zheng.demo3;

public interface INote {
    void edit();
}

具体产品
python下的具体产品viedo

package com.zheng.demo3;

public class PythonViedo implements IViedo {
    @Override
    public void record() {
        System.out.println("我是python相关的视频");
    }
}

python下的具体产品note

package com.zheng.demo3;

public class PythonNote implements INote {
    @Override
    public void edit() {
        System.out.println("我是Python相关的笔记");
    }
}

生产python相关的工厂

package com.zheng.demo3;

public class createPythonFactory implements CourseFactory {
    @Override
    public INote cerateNote() {
        return new PythonNote();
    }

    @Override
    public IViedo cerateViedo() {
        return new PythonViedo();
    }
}

客户端测试

package com.zheng.demo3;

public class TestClient {
    public static void main(String[] args) {
        //1、创建具体工厂
        CourseFactory factory = new createPythonFactory();

        //2、通过工厂创建商品
        IViedo viedo = factory.cerateViedo();
        INote note = factory.cerateNote();

        //3、调用实例的方法
        viedo.record();
        note.edit();
    }
}

结果
在这里插入图片描述
。还可以继续扩展其他的课程、比如python、c语言、C++。只需要扩展对应的实现类和对应的工厂生产就可以了。

7、抽象工厂模式优点

优点

  • 需要产品族时,可以保证客户端只使用一个产品的产品族
  • 增强了程序的可扩展性,新产品族的增加,只需要实现一个新的具体工厂就可以

缺点

  • 规定了所有可能被创建的产品集合,产品族扩展新商品、需要修改抽象工厂的接口
  • 增加了系统的抽象性和难理解度。
相关文章
|
3月前
|
设计模式
**工厂模式与抽象工厂模式**都是创建型设计模式,用于封装对象创建,减少耦合
【6月更文挑战第23天】**工厂模式与抽象工厂模式**都是创建型设计模式,用于封装对象创建,减少耦合。工厂模式专注于单个对象,通过具体工厂创建具体产品,适用于简单对象创建;抽象工厂则关注一系列相关产品,提供创建一族对象的接口,适用于处理多个不兼容产品族。选择模式基于问题域的复杂性,单个产品需求时用工厂模式,多产品族时用抽象工厂模式。
28 5
|
14天前
|
设计模式 Java
Java 设计模式之谜:工厂模式与抽象工厂模式究竟隐藏着怎样的神奇力量?
【8月更文挑战第30天】在Java编程中,设计模式为常见问题提供了高效解决方案。工厂模式与抽象工厂模式是常用的对象创建型设计模式,能显著提升代码的灵活性、可维护性和可扩展性。工厂模式通过定义创建对象的接口让子类决定实例化哪个类;而抽象工厂模式则进一步提供了一个创建一系列相关或相互依赖对象的接口,无需指定具体类。这种方式使得系统更易于扩展和维护。
28 1
|
18天前
|
设计模式 算法 开发者
深入理解工厂模式与策略模式:设计模式的灵活应用
深入理解工厂模式与策略模式:设计模式的灵活应用
|
25天前
|
设计模式 XML 存储
【三】设计模式~~~创建型模式~~~抽象工厂模式(Java)
文章详细介绍了抽象工厂模式,这是一种创建型设计模式,用于提供一个接口以创建一系列相关或相互依赖的对象,而不指定它们具体的类。通过代码示例和结构图,文章展示了抽象工厂模式的动机、定义、结构、优点、缺点以及适用场景,并探讨了如何通过配置文件和反射机制实现工厂的动态创建。
【三】设计模式~~~创建型模式~~~抽象工厂模式(Java)
|
29天前
|
设计模式 uml C语言
设计模式----------工厂模式之简单工厂模式(创建型)
这篇文章详细介绍了简单工厂模式,包括其定义、应用场景、UML类图、通用代码实现、运行结果、实际应用例子,以及如何通过反射机制实现对象创建,从而提高代码的扩展性和维护性。
设计模式----------工厂模式之简单工厂模式(创建型)
|
30天前
|
设计模式 uml
设计模式-------------工厂模式之工厂方法模式(创建型)
工厂方法模式是一种创建型设计模式,它通过定义一个用于创建对象的接口,让子类决定实例化哪一个类,从而实现类的实例化推迟到子类中进行,提高了系统的灵活性和可扩展性。
|
1月前
|
设计模式 存储 XML
[设计模式]创建型模式-抽象工厂模式
[设计模式]创建型模式-抽象工厂模式
|
2月前
|
设计模式 C++
C++一分钟之-设计模式:工厂模式与抽象工厂
【7月更文挑战第14天】设计模式是解决软件设计问题的通用方案。工厂模式与抽象工厂模式是创建型模式,用于对象创建而不暴露创建逻辑。工厂模式推迟实例化到子类,但过度使用会增加复杂性。抽象工厂则创建相关对象族,但过度抽象可能造成不必要的复杂度。两者均应按需使用,确保设计灵活性。代码示例展示了C++中如何实现这两种模式。
34 3
|
2月前
|
设计模式 安全 Java
Java面试题:设计模式如单例模式、工厂模式、观察者模式等在多线程环境下线程安全问题,Java内存模型定义了线程如何与内存交互,包括原子性、可见性、有序性,并发框架提供了更高层次的并发任务处理能力
Java面试题:设计模式如单例模式、工厂模式、观察者模式等在多线程环境下线程安全问题,Java内存模型定义了线程如何与内存交互,包括原子性、可见性、有序性,并发框架提供了更高层次的并发任务处理能力
60 1
|
3月前
|
设计模式 Java
Java设计模式:工厂模式之简单工厂、工厂方法、抽象工厂(三)
Java设计模式:工厂模式之简单工厂、工厂方法、抽象工厂(三)