重学 Java 设计模式:实战抽象工厂模式

本文涉及的产品
云数据库 Tair(兼容Redis),内存型 2GB
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
简介: 重学 Java 设计模式:实战抽象工厂模式

重学 Java 设计模式:实战抽象工厂模式

今天我们来谈一下 Java 设计模式中的抽象工厂模式,以实战方式来介绍。我们将以升级 Redis 双集群,代理类抽象场景为例,通过抽象工厂模式的实现,来解决代理类升级问题,提高程序的可维护性、可扩展性和可读性。

什么是抽象工厂模式

抽象工厂模式是一种创建型设计模式,它允许创建一系列相关的对象,而无需指定其具体类别。抽象工厂模式通过抽象化工厂类和具体工厂类的方式,实现了客户端和具体实现类的分离。客户端只需要知道抽象工厂和抽象产品接口,就可以使用一组产品,无需知道具体的实现。

抽象工厂模式优点

  • 增强程序的可维护性和可扩展性,提高程序的可读性
  • 通过工厂方法封装了对象的创建过程,避免了客户端直接依赖具体实现类
  • 可以轻松地替换不同的具体实现类,无需修改客户端代码

升级 Redis 双集群场景

假设我们现在有一个 Redis 双集群场景,其中一个集群存放请求较少的数据,另一个集群存放请求较多的数据。我们希望通过代理类实现在请求量超过阈值的时候,自动切换到请求量较大的集群中。

下面我们通过抽象工厂模式实现此场景。

实现思路

我们可以通过抽象工厂模式,为请求量较大的集群中的代理类进行替换。具体实现步骤如下:

  1. 定义抽象工厂接口,包含创建一系列代理类的方法。
  2. 定义抽象产品接口,包含获取请求量、代理转发等方法。
  3. 创建具体产品类,分别实现抽象产品接口,即代理类功能实现。
  4. 创建具体工厂类,实现抽象工厂接口,用于创建与请求量对应的具体代理类。
  5. 在客户端中,使用抽象工厂和抽象产品接口,通过配置文件或者其他方式,选择对应的工厂类,来创建具体代理类。

通过这样的实现方式,我们可以轻松地替换掉具体的代理类,而无需对客户端进行任何修改。

实现代码

抽象工厂接口

public interface ProxyFactory {
    /**
     * 获取代理类
     *
     * @return 抽象产品
     */
    Proxy getProxy();
}

抽象产品接口

public interface Proxy {
    /**
     * 获取请求量
     *
     * @return 请求量
     */
    int getRequestCount();
    /**
     * 代理转发
     *
     * @param request 请求
     * @return 响应
     */
    String proxy(String request);
}

具体产品类

请求量较小的代理类

public class SmallProxy implements Proxy {
    @Override
    public int getRequestCount() {
        return 1000;
    }
    @Override
    public String proxy(String request) {
        // 实现请求转发逻辑
        return "SmallProxy: " + request;
    }
}

请求量较大的代理类

public class BigProxy implements Proxy {
    @Override
    public int getRequestCount() {
        return 10000;
    }
    @Override
    public String proxy(String request) {
        // 实现请求转发逻辑
        return "BigProxy: " + request;
    }
}

具体工厂类

public class ProxyFactoryImpl implements ProxyFactory {
    private static final String CLUSTER_CONFIG = "cluster.properties";
    private static final String SMALL_PROXY_CLASS = "small_proxy_class";
    private static final String BIG_PROXY_CLASS = "big_proxy_class";
    /**
     * 根据请求量创建具体代理类
     *
     * @return 抽象产品
     */
    @Override
    public Proxy getProxy() {
        Properties properties = new Properties();
        try {
            properties.load(new FileInputStream(new File(CLUSTER_CONFIG)));
        } catch (IOException e) {
            throw new RuntimeException("无法读取配置文件", e);
        }
        int requestCount = 0; // 获取请求量
        if (requestCount < 5000) { // 根据请求量选择具体代理类
            String smallProxyClass = properties.getProperty(SMALL_PROXY_CLASS);
            try {
                return (Proxy) Class.forName(smallProxyClass).newInstance();
            } catch (InstantiationException | IllegalAccessException | ClassNotFoundException e) {
                throw new RuntimeException("无法实例化小型代理类", e);
            }
        } else {
            String bigProxyClass = properties.getProperty(BIG_PROXY_CLASS);
            try {
                return (Proxy) Class.forName(bigProxyClass).newInstance();
            } catch (InstantiationException | IllegalAccessException | ClassNotFoundException e) {
                throw new RuntimeException("无法实例化大型代理类", e);
            }
        }
    }
}

客户端代码

public class App {
    public static void main(String[] args) {
        ProxyFactory proxyFactory = new ProxyFactoryImpl();
        Proxy proxy = proxyFactory.getProxy();
        // 使用代理类实现请求转发
        System.out.println(proxy.proxy("hello world!"));
    }
}

配置文件

small_proxy_class=cn.example.SmallProxy
big_proxy_class=cn.example.BigProxy

结语

本文通过实战的方式介绍了 Java 设计模式中的抽象工厂模式,并以升级 Redis 双集群,代理类抽象场景为例,演示了抽象工厂模式的实现思路和具体代码实现。在实际开发中,设计模式可以提高程序的可读性、可重用性和可维护性,希望本文对您有所帮助。


相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore &nbsp; &nbsp; ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库&nbsp;ECS 实例和一台目标数据库&nbsp;RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&amp;RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
目录
相关文章
|
27天前
|
存储 Java 开发者
Java Map实战:用HashMap和TreeMap轻松解决复杂数据结构问题!
【10月更文挑战第17天】本文深入探讨了Java中HashMap和TreeMap两种Map类型的特性和应用场景。HashMap基于哈希表实现,支持高效的数据操作且允许键值为null;TreeMap基于红黑树实现,支持自然排序或自定义排序,确保元素有序。文章通过具体示例展示了两者的实战应用,帮助开发者根据实际需求选择合适的数据结构,提高开发效率。
59 2
|
1月前
|
存储 消息中间件 安全
JUC组件实战:实现RRPC(Java与硬件通过MQTT的同步通信)
【10月更文挑战第9天】本文介绍了如何利用JUC组件实现Java服务与硬件通过MQTT的同步通信(RRPC)。通过模拟MQTT通信流程,使用`LinkedBlockingQueue`作为消息队列,详细讲解了消息发送、接收及响应的同步处理机制,包括任务超时处理和内存泄漏的预防措施。文中还提供了具体的类设计和方法实现,帮助理解同步通信的内部工作原理。
JUC组件实战:实现RRPC(Java与硬件通过MQTT的同步通信)
|
24天前
|
设计模式 Java 程序员
[Java]23种设计模式
本文介绍了设计模式的概念及其七大原则,强调了设计模式在提高代码重用性、可读性、可扩展性和可靠性方面的作用。文章还简要概述了23种设计模式,并提供了进一步学习的资源链接。
36 0
[Java]23种设计模式
|
29天前
|
开发框架 Java 程序员
揭开Java反射的神秘面纱:从原理到实战应用!
本文介绍了Java反射的基本概念、原理及应用场景。反射允许程序在运行时动态获取类的信息并操作其属性和方法,广泛应用于开发框架、动态代理和自定义注解等领域。通过反射,可以实现更灵活的代码设计,但也需注意其性能开销。
45 1
|
8天前
|
设计模式 JavaScript Java
Java设计模式:建造者模式详解
建造者模式是一种创建型设计模式,通过将复杂对象的构建过程与表示分离,使得相同的构建过程可以创建不同的表示。本文详细介绍了建造者模式的原理、背景、应用场景及实际Demo,帮助读者更好地理解和应用这一模式。
|
1月前
|
设计模式 监控 算法
Java设计模式梳理:行为型模式(策略,观察者等)
本文详细介绍了Java设计模式中的行为型模式,包括策略模式、观察者模式、责任链模式、模板方法模式和状态模式。通过具体示例代码,深入浅出地讲解了每种模式的应用场景与实现方式。例如,策略模式通过定义一系列算法让客户端在运行时选择所需算法;观察者模式则让多个观察者对象同时监听某一个主题对象,实现松耦合的消息传递机制。此外,还探讨了这些模式与实际开发中的联系,帮助读者更好地理解和应用设计模式,提升代码质量。
Java设计模式梳理:行为型模式(策略,观察者等)
|
2月前
|
设计模式 存储 缓存
Java设计模式 - 解释器模式(24)
Java设计模式 - 解释器模式(24)
|
1月前
|
设计模式 Java
Java设计模式
Java设计模式
28 0
|
1月前
|
设计模式 Java
Java设计模式之外观模式
这篇文章详细解释了Java设计模式之外观模式的原理及其应用场景,并通过具体代码示例展示了如何通过外观模式简化子系统的使用。
29 0
|
1月前
|
设计模式 Java
Java设计模式之桥接模式
这篇文章介绍了Java设计模式中的桥接模式,包括桥接模式的目的、实现方式,并通过具体代码示例展示了如何分离抽象与实现,使得两者可以独立变化。
43 0