设计模式--抽象工厂模式

抽象工厂模式(Abstract Factory Pattern)详解

在软件开发中,当我们需要创建一组相关或互相依赖的对象时,简单工厂模式和工厂方法模式可能显得力不从心。此时,抽象工厂模式(Abstract Factory Pattern)就派上用场了。本文将深入探讨抽象工厂模式,帮助你理解和应用这一强大的设计模式。

什么是抽象工厂模式?

抽象工厂模式是一种创建型设计模式,它提供了一个接口,用于创建相关或依赖对象的家族,而无需明确指定具体类。通过抽象工厂模式,我们可以将一组相关对象的创建逻辑封装在一起,从而实现对象创建的高内聚和低耦合。

示例:创建不同类型的形状和颜色对象

为了更好地理解抽象工厂模式,我们来看一个具体的示例。假设我们需要创建不同类型的形状(如圆形、矩形和正方形)以及颜色(如红色、绿色和蓝色)对象。

第一步:定义抽象产品接口

首先,我们定义形状和颜色的抽象产品接口。

java 复制代码
// 形状接口
public interface Shape {
    void draw();
}

// 颜色接口
public interface Color {
    void fill();
}
第二步:创建具体产品类

接下来,我们创建实现 ShapeColor 接口的具体产品类。

java 复制代码
// 具体形状类
public class Circle implements Shape {
    @Override
    public void draw() {
        System.out.println("Drawing a Circle");
    }
}

public class Rectangle implements Shape {
    @Override
    public void draw() {
        System.out.println("Drawing a Rectangle");
    }
}

public class Square implements Shape {
    @Override
    public void draw() {
        System.out.println("Drawing a Square");
    }
}

// 具体颜色类
public class Red implements Color {
    @Override
    public void fill() {
        System.out.println("Filling with Red");
    }
}

public class Green implements Color {
    @Override
    public void fill() {
        System.out.println("Filling with Green");
    }
}

public class Blue implements Color {
    @Override
    public void fill() {
        System.out.println("Filling with Blue");
    }
}
第三步:定义抽象工厂接口

我们定义一个抽象工厂接口,用于创建形状和颜色对象。

java 复制代码
public interface AbstractFactory {
    Shape createShape(String shapeType);
    Color createColor(String colorType);
}
第四步:创建具体工厂类

然后,我们创建实现 AbstractFactory 接口的具体工厂类,每个具体工厂类负责创建一种产品族。

java 复制代码
public class ShapeFactory implements AbstractFactory {
    @Override
    public Shape createShape(String shapeType) {
        if (shapeType == null) {
            return null;
        }
        if (shapeType.equalsIgnoreCase("CIRCLE")) {
            return new Circle();
        } else if (shapeType.equalsIgnoreCase("RECTANGLE")) {
            return new Rectangle();
        } else if (shapeType.equalsIgnoreCase("SQUARE")) {
            return new Square();
        }
        return null;
    }

    @Override
    public Color createColor(String colorType) {
        return null; // ShapeFactory 不负责创建颜色对象
    }
}

public class ColorFactory implements AbstractFactory {
    @Override
    public Shape createShape(String shapeType) {
        return null; // ColorFactory 不负责创建形状对象
    }

    @Override
    public Color createColor(String colorType) {
        if (colorType == null) {
            return null;
        }
        if (colorType.equalsIgnoreCase("RED")) {
            return new Red();
        } else if (colorType.equalsIgnoreCase("GREEN")) {
            return new Green();
        } else if (colorType.equalsIgnoreCase("BLUE")) {
            return new Blue();
        }
        return null;
    }
}
第五步:创建工厂生成器类

为了简化客户端代码,我们创建一个工厂生成器类,用于获取具体工厂类的实例。

java 复制代码
public class FactoryProducer {
    public static AbstractFactory getFactory(String choice) {
        if (choice.equalsIgnoreCase("SHAPE")) {
            return new ShapeFactory();
        } else if (choice.equalsIgnoreCase("COLOR")) {
            return new ColorFactory();
        }
        return null;
    }
}
第六步:使用抽象工厂模式创建对象

最后,我们在客户端代码中使用抽象工厂模式来创建不同的形状和颜色对象。

java 复制代码
public class Client {
    public static void main(String[] args) {
        AbstractFactory shapeFactory = FactoryProducer.getFactory("SHAPE");
        Shape shape1 = shapeFactory.createShape("CIRCLE");
        shape1.draw();

        Shape shape2 = shapeFactory.createShape("RECTANGLE");
        shape2.draw();

        AbstractFactory colorFactory = FactoryProducer.getFactory("COLOR");
        Color color1 = colorFactory.createColor("RED");
        color1.fill();

        Color color2 = colorFactory.createColor("GREEN");
        color2.fill();
    }
}
抽象工厂模式的优点
  1. 分离接口与实现:抽象工厂模式通过工厂接口将客户端代码与具体类的实现分离,使代码更具灵活性。
  2. 提高可扩展性:添加新的产品族时,只需创建新的具体工厂类,不需要修改现有代码,符合开闭原则(Open/Closed Principle)。
  3. 一致的对象创建:确保同一产品族的对象在客户端代码中始终以一致的方式创建。
抽象工厂模式的缺点
  1. 增加系统复杂度:由于需要定义多个工厂类和产品类,系统的类数量增加,复杂度提高。
  2. 难以支持新种类的产品:如果需要添加新的产品类型(而不是新的产品族),可能需要修改抽象工厂接口及其所有实现类。
总结

抽象工厂模式通过提供一个创建一系列相关或依赖对象的接口,极大地增强了代码的可扩展性和可维护性。尽管其实现较为复杂,但在需要创建多个相关对象且希望保证创建过程的一致性时,抽象工厂模式是一个非常有力的工具。希望通过这个示例,你能更好地理解和应用抽象工厂模式,让你的代码更加优雅和高效。

相关推荐
蓝染-惣右介5 分钟前
【23种设计模式·全精解析 | 行为型模式篇】11种行为型模式的结构概述、案例实现、优缺点、扩展对比、使用场景、源码解析
java·设计模式
捕鲸叉4 小时前
C++软件设计模式之类型模式和对象型模式
开发语言·c++·设计模式
诸葛悠闲5 小时前
设计模式——组合模式
设计模式·组合模式
诸葛悠闲5 小时前
设计模式——装饰模式
设计模式
西岭千秋雪_5 小时前
设计模式の中介者&发布订阅&备忘录模式
java·观察者模式·设计模式·中介者模式·备忘录模式
捕鲸叉5 小时前
C++软件设计模式之代理(Proxy)模式
c++·设计模式
思忖小下5 小时前
梳理你的思路(从OOP到架构设计)_介绍GoF设计模式
设计模式·架构·eit
重生之绝世牛码5 小时前
Java设计模式 —— 【结构型模式】享元模式(Flyweight Pattern) 详解
java·大数据·开发语言·设计模式·享元模式·设计原则
越甲八千9 小时前
重温设计模式--代理、中介者、适配器模式的异同
设计模式·适配器模式