java进阶(三):单例、工厂、模版方法与代理模式详解

单例模式:确保唯一实例

单例模式的核心目标是确保一个类在整个应用程序中只有一个实例,并提供一个全局访问点。

实现方式

饿汉式单例

java 复制代码
public class Runtime {
    private static Runtime currentRuntime = new Runtime();
    
    public static Runtime getRuntime() {
        return currentRuntime;
    }
    
    private Runtime() {}
}
 
  • 优点:线程安全,实现简单

  • 缺点:类加载时就创建实例,可能延长启动时间

懒汉式单例(双重检查锁定)

java 复制代码
public class Window {
    private volatile static Window window = null;
    
    private Window() {}
    
    public static Window getWindow() {
        if(window == null) {
            synchronized (Window.class) {
                if(window == null) {
                    window = new Window();
                }
            }
        }
        return window;
    }
}
 
  • volatile关键字防止指令重排序

  • 双重检查减少同步开销

  • 优点:延迟加载,节省资源

  • 缺点:实现稍复杂

工厂模式:对象创建的艺术

工厂模式解决对象创建的问题,分为简单工厂、工厂方法和抽象工厂三种形式。

1. 简单工厂

java 复制代码
public class CanFactory {
    public static Can createCan(String name) {
        if(name.equals("aodi")) return new Aodi();
        if(name.equals("bmw")) return new Bmw();
        if(name.equals("dazhong")) return new Dazhong();
        return null;
    }
}
 
  • 优点:集中管理对象创建

  • 缺点:违反开闭原则,新增产品需要修改工厂代码

2. 工厂方法

java 复制代码
public abstract class Factory {
    public abstract Product createProduct();
}
 
  • 为每个产品提供一个专门工厂

  • 优点:符合开闭原则,扩展性好

  • 缺点:类数量增多

3. 抽象工厂

java 复制代码
public interface AbstractFactory {
    Button createButton();
    Checkbox createCheckbox();
}
 
  • 一个工厂可以创建同一产品族的不同产品

  • 适合产品族扩展场景

  • 例如:汽车工厂生产轿车、SUV等多类型车辆

模版方法模式:定义算法骨架

java 复制代码
abstract class Template {
    // 模版方法定义流程
    public final void templateMethod() {
        step1();
        step2();
        step3();
    }
    
    // 固定实现
    private void step1() { /*...*/ }
    
    // 需要子类实现
    protected abstract void step2();
    
    // 可选实现
    protected void step3() { /*默认实现*/ }
}
 
  • 优点:代码复用,反向控制

  • 缺点:增加系统复杂度

代理模式:控制对象访问

1. 静态代理

java 复制代码
interface Subject {
    void request();
}

class RealSubject implements Subject {
    public void request() { /*业务逻辑*/ }
}

class Proxy implements Subject {
    private RealSubject realSubject;
    
    public void request() {
        preRequest();
        realSubject.request();
        postRequest();
    }
}
 
  • 优点:不修改目标对象即可扩展功能

  • 缺点:一个代理类只能代理一种类型

2. 动态代理

JDK动态代理

java 复制代码
// JDK 动态代理
Proxy.newProxyInstance(
    target.getClass().getClassLoader(),
    target.getClass().getInterfaces(),
    (proxy, method, args) -> {
        // 前置处理
        Object result = method.invoke(target, args);
        // 后置处理
        return result;
    });
 
  • 要求目标类必须实现接口

CGLIB代理

  • 通过生成子类实现代理

  • 不要求目标类实现接口

  • Spring AOP默认使用方式

总结

设计模式是解决特定问题的优秀实践:

  1. 单例模式确保全局唯一实例

  2. 工厂模式封装对象创建过程

  3. 模版方法模式固定算法流程

  4. 代理模式控制对象访问

合理运用这些模式可以使代码更灵活、更易维护,但也要避免过度设计。根据实际场景选择最适合的模式才是关键。

相关推荐
咖啡Beans4 小时前
使用OpenFeign实现微服务间通信
java·spring cloud
我不是混子4 小时前
说说单例模式
java
间彧6 小时前
SimpleDateFormat既然不推荐使用,为什么java 8+中不删除此类
java
间彧6 小时前
DateTimeFormatter相比SimpleDateFormat在性能上有何差异?
java
间彧7 小时前
为什么说SimpleDateFormat是经典的线程不安全类
java
MacroZheng7 小时前
横空出世!MyBatis-Plus 同款 ES ORM 框架,用起来够优雅!
java·后端·elasticsearch
用户0332126663677 小时前
Java 查找并替换 Excel 中的数据:详细教程
java
间彧7 小时前
ThreadLocal实现原理与应用实践
java
若水不如远方8 小时前
Netty的四种零拷贝机制:深入原理与实战指南
java·netty