设计模式-抽象工厂模式

定义理解

抽象工厂模式是一种为访问一系列相互关联的产品对象提供统一接口,而无需指定它们具体的类。抽象工厂模式可以创建多个不同类型的产品,这些产品构成一个产品族。

简单来说,当抽象工厂模式如果只有一个产品体系的话就会退化为工厂方法模式

特点:

  • 产品族:一系列相互关联或相互依赖的产品对象。
  • 多个抽象产品:每个抽象产品都可以有多个具体实现。
  • 接口数量:理论上可以有无限个接口,每个接口对应一个产品族。
  • 开闭原则:在新增产品族时符合"开闭原则",但在新增单一产品时可能不符合。

图解

代码示例

java 复制代码
// 抽象产品:日志接口  
interface Logger {  
    void log(String message);  
}  
  
// 具体产品:Log4j 日志实现  
class Log4jLogger implements Logger {  
    @Override  
    public void log(String message) {  
        System.out.println("Log4j: " + message);  
    }  
}  
  
// 具体产品:Logback 日志实现  
class LogbackLogger implements Logger {  
    @Override  
    public void log(String message) {  
        System.out.println("Logback: " + message);  
    }  
}  
  
// 抽象产品:不同日志级别的接口  
interface LogLevel {  
    void log(Logger logger, String message);  
}  
  
// 具体产品:DEBUG 日志级别实现  
class DebugLogLevel implements LogLevel {  
    @Override  
    public void log(Logger logger, String message) {  
        logger.log("[DEBUG] " + message);  
    }  
}  
  
// 具体产品:ERROR 日志级别实现  
class ErrorLogLevel implements LogLevel {  
    @Override  
    public void log(Logger logger, String message) {  
        logger.log("[ERROR] " + message);  
    }  
}  
  
// 抽象工厂:日志工厂接口  
interface LoggerFactory {  
    Logger getLogger();  
    LogLevel getLogLevel(String level);  
}  
  
// 具体工厂:Log4j 日志工厂实现  
class Log4jLoggerFactory implements LoggerFactory {  
    @Override  
    public Logger getLogger() {  
        return new Log4jLogger();  
    }  
  
    @Override  
    public LogLevel getLogLevel(String level) {  
        if ("DEBUG".equalsIgnoreCase(level)) {  
            return new DebugLogLevel();  
        } else if ("ERROR".equalsIgnoreCase(level)) {  
            return new ErrorLogLevel();  
        }  
        // 其他情况可以抛出异常或返回默认实现  
        return null;  
    }  
}  
  
// 客户端代码  
public class Client {  
    public static void main(String[] args) {  
        // 使用 Log4j 日志工厂创建日志实例和日志级别实例  
        LoggerFactory log4jFactory = new Log4jLoggerFactory();  
        Logger log4jLogger = log4jFactory.getLogger();  
        LogLevel debugLevel = log4jFactory.getLogLevel("DEBUG");  
        LogLevel errorLevel = log4jFactory.getLogLevel("ERROR");  
  
        debugLevel.log(log4jLogger, "This is a Log4j DEBUG log message.");  
        errorLevel.log(log4jLogger, "This is a Log4j ERROR log message.");  
    }  
}

与其他模式的对比

  1. 抽象工厂模式 vs 简单工厂模式
  • 定义变量:简单工厂模式使用参数或配置文件等定义好的变量;抽象工厂模式每次新增产品都需要修改类方法。
  • 接口数量:简单工厂模式只有一个接口;抽象工厂模式可以有多个接口。
  • 扩展性:简单工厂模式系统扩展困难,添加新产品需要修改工厂逻辑;抽象工厂模式则更适合创建产品族。
  1. 抽象工厂模式 vs 工厂方法模式
  • 产品范围:工厂方法模式针对一个抽象产品类进行创建;抽象工厂模式则针对多个抽象产品类创建。
  • 工厂数量:工厂方法模式的具体工厂类只能创建一个具体产品类的实例;抽象工厂模式的具体工厂类可以创建多个具体产品类的实例。
  • 适用场景:工厂方法模式适用于需要扩展产品类型但不关心产品族之间关系的场景;抽象工厂模式适用于需要创建多个产品族且产品族之间有相互关联的场景。
相关推荐
碳水加碳水3 分钟前
Java代码审计实战:XML外部实体注入(XXE)深度解析
java·安全·web安全·代码审计
TechNomad1 小时前
设计模式:状态模式(State Pattern)
设计模式·状态模式
努力也学不会java1 小时前
【设计模式】 原型模式
java·设计模式·原型模式
方渐鸿1 小时前
【2024】k8s集群 图文详细 部署安装使用(两万字)
java·运维·容器·kubernetes·k8s·运维开发·持续部署
学亮编程手记2 小时前
K8S v1.33 版本主要新特性介绍
java·容器·kubernetes
Haven-3 小时前
Java-面试八股文-JVM篇
java·jvm·面试
我真的是大笨蛋3 小时前
JVM调优总结
java·jvm·数据库·redis·缓存·性能优化·系统架构
wjs0403 小时前
Git常用的命令
java·git·gitlab
superlls3 小时前
(算法 哈希表)【LeetCode 349】两个数组的交集 思路笔记自留
java·数据结构·算法
TechNomad3 小时前
设计模式:模板方法模式(Template Method Pattern)
设计模式·模板方法模式