当前位置: 首页 > news >正文

JAVA设计模式,动态代理模式

动态代理(Dynamic Proxy)是Java中一种非常有用的设计模式。它允许在运行时创建一个实现了一组给定接口的新类。这种模式主要用于当需要为某个对象提供一个代理以控制对该对象的访问时。通过这种方式,可以添加额外的功能,如事务管理、安全检查等,而无需修改原始对象的代码。

### 动态代理的主要组成部分

1. **接口**:定义一组方法,代理类和被代理类都需要实现这些方法。
2. **被代理类**:实现了上述接口的实际业务逻辑类。
3. **InvocationHandler**:这是一个接口,它有一个方法`invoke`,该方法负责处理所有的方法调用。这个接口的实例包含了对被代理对象的引用,并且可以在这个方法中添加额外的操作。
4. **代理类**:这是由Java反射机制动态生成的一个类,它实现了与被代理类相同的接口。当通过代理对象调用方法时,实际上会调用到`InvocationHandler`中的`invoke`方法。

### 实现步骤

1. 定义一个或多个接口。
2. 创建实现这些接口的被代理类。
3. 创建一个实现了`InvocationHandler`接口的类,该类包含对被代理对象的引用,并在`invoke`方法中实现所需的额外操作。
4. 使用`Proxy.newProxyInstance`方法来创建代理对象。

### 示例代码

假设我们有一个简单的接口`MyInterface`,以及其实现类`MyRealObject`。

#### 接口

```java
public interface MyInterface {
    void doSomething();
}
```

#### 被代理类

```java
public class MyRealObject implements MyInterface {
    @Override
    public void doSomething() {
        System.out.println("Doing something...");
    }
}
```

#### InvocationHandler 实现

```java
import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;

public class MyInvocationHandler implements InvocationHandler {
    private final Object target;

    public MyInvocationHandler(Object target) {
        this.target = target;
    }

    @Override
    public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
        System.out.println("Before method call");
        Object result = method.invoke(target, args);
        System.out.println("After method call");
        return result;
    }
}
```

#### 创建代理对象并使用

```java
import java.lang.reflect.Proxy;

public class Main {
    public static void main(String[] args) {
        MyInterface realObject = new MyRealObject();
        MyInterface proxyObject = (MyInterface) Proxy.newProxyInstance(
                MyInterface.class.getClassLoader(),
                new Class[]{MyInterface.class},
                new MyInvocationHandler(realObject)
        );

        proxyObject.doSomething(); // 通过代理对象调用方法
    }
}
```

以上示例展示了如何使用Java的动态代理模式。当你运行这段代码时,你会看到输出不仅包括`doSomething`方法的执行结果,还有我们在`MyInvocationHandler`中添加的前后操作信息。这正是动态代理的魅力所在——能够在不改变原有业务逻辑的情况下,轻松地添加新的功能。

http://www.lryc.cn/news/496884.html

相关文章:

  • HTML 快速上手
  • 【计算机视觉算法与应用】模板匹配、图像配准
  • 【Linux】设计文件系统(C实现)
  • 详解Rust多线程编程
  • el-upload上传多个文件,一次请求,Django接收
  • Python实现网站资源批量下载【可转成exe程序运行】
  • 《JavaScript高级程序设计》读书笔记 20
  • ASP.NET Core项目中使用SqlSugar连接多个数据库的方式
  • Java面试八股文(精选、纯手打)
  • 工程设计行业内外网文件交换解决方案:FileLink助力高效、安全的跨网协作
  • Qt 2D绘图之三:绘制文字、路径、图像、复合模式
  • 配置宝塔php curl 支持http/2 发送苹果apns消息推送
  • Redis服务配置文件 redis.conf 更新修改配置参数说明
  • Android 俩个主题的不同之处 “Theme.AppCompat vs android:Theme.Material.Light.NoActionBar”
  • Redis+Caffeine 多级缓存数据一致性解决方案
  • vscode ctrl+/注释不了css
  • 《山海经》:北山
  • oracle中删除指定前缀的表
  • 解决 Flutter Dio合并请求多个接口,如果一个接口500,那么导致其他请求不在执行
  • The selected directory is not a valid home for Go SDK
  • 基于云模型的车辆行驶速度估计算法matlab仿真
  • MySQL有哪些日志?
  • Axios:现代JavaScript HTTP客户端
  • python学opencv|读取视频(一)灰度视频制作和保存
  • 【Rust WebAssembly 入门实操遇到的问题】
  • 掌握CMake中的变量:设置、使用及实际应用示例详解
  • React基础知识三 router路由全指南
  • [VUE]框架网页开发02-如何打包Vue.js框架网页并在服务器中通过Tomcat启动
  • k8s Quality of Service
  • 顶刊算法 | 鱼鹰算法OOA-BiTCN-BiGRU-Attention多输入单输出回归预测(Maltab)