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

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、抽象工厂模式优点

优点

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

缺点

  • 规定了所有可能被创建的产品集合,产品族扩展新商品、需要修改抽象工厂的接口
  • 增加了系统的抽象性和难理解度。
posted on 2022-08-28 22:18  热爱技术的小郑  阅读(31)  评论(0编辑  收藏  举报