jdk动态代理实现

jdk动态代理是比较常用的一种代理实现,**它是基于接口的代理。它只能在运行时为接口生成代理对象,所有方法调用都通过一个统一的InvocationHandler处理,是Java标准库自带的代理机制。**核心要点:

  1. 必须要有接口

  2. 运行时动态生成

  3. 通过InvocationHandler统一拦截

  4. JDK自带,无需第三方库

下面的案例简单的进行了实现。

1.接口

java 复制代码
    interface Foo{
        void foo();
    }

2.目标类

java 复制代码
    static class Target implements Foo{
        public void foo(){
            System.out.println("target foo");
        }
    }

3.jdk代理创建以及调用

java 复制代码
 //目标对象
        Target target = new Target();
        //用来加载在运行期间动态生成的字节码
        ClassLoader loader = testJdkProxy.class.getClassLoader();
        Foo proxy = (Foo) Proxy.newProxyInstance(loader,new Class[]{Foo.class},(p,method,params)->{
            System.out.println("before");
            //目标 方法(参数)
            // 方法.invoke(目标,参数);
            Object result = method.invoke(target,params);
            System.out.println("after");
            return result;//让代理返回目标方法执行的结果
        });
        proxy.foo();

1)创建目标对象

  1. 获取classLoader

3)生成代理对象

设置创建代理需要的参数,同时通过匿名内部类实现InvocationHandler里面的方法进行目标类方法调用前后的增强逻辑处理,目标类方法的调用是通过反射进行。最后返回调用结果。

4)代理对象调用目标方法进行增强

5)总体代码实现

java 复制代码
package com.example.demo2.b07;

import java.lang.reflect.Proxy;

/**
 * @author zhou
 * @version 1.0
 * @description TODO
 * @date 2025/10/25 22:21
 */
public class testJdkProxy {
    interface Foo{
        void foo();
    }
    static class Target implements Foo{
        public void foo(){
            System.out.println("target foo");
        }
    }

    public static void main(String[] args) {
        //目标对象
        Target target = new Target();
        //用来加载在运行期间动态生成的字节码
        ClassLoader loader = testJdkProxy.class.getClassLoader();
        Foo proxy = (Foo) Proxy.newProxyInstance(loader,new Class[]{Foo.class},(p,method,params)->{
            System.out.println("before");
            //目标 方法(参数)
            // 方法.invoke(目标,参数);
            Object result = method.invoke(target,params);
            System.out.println("after");
            return result;//让代理返回目标方法执行的结果
        });
        proxy.foo();
        
    }
}

4.结果

对目标类的方法进行了前后增强。

相关推荐
开发小能手-roy11 小时前
StringBuilder vs StringBuffer:2024年还需要线程安全字符串吗?
开发语言·python·安全
开发小能手-roy11 小时前
Java集合框架选型指南:从ArrayList到ConcurrentSkipListMap
java·开发语言
凡人叶枫11 小时前
Effective C++ 条款41:了解隐式接口和编译期多态
java·开发语言·c++·effective c++
凡人叶枫11 小时前
Effective C++ 条款42:了解 typename 的双重意义
java·linux·服务器·c++
2601_9547064912 小时前
云手机技术详解+Python实战调用|2026高稳云手机平台推荐
开发语言·python·智能手机
chushiyunen12 小时前
java中的路径处理、左右斜杠
java·开发语言·python
yyxx41212312 小时前
上海企业如何选择专业的钉钉服务商
java·大数据·人工智能·钉钉
一杯奶茶¥12 小时前
水果销售网站 CRM客户信息管理系统 超市管理系 酒店管理系统 健身房管理系统 在线音乐网站 校园招聘系统
java·vue.js·spring boot·mysql·spring·java项目
重生之后端学习12 小时前
Java入门
java·开发语言·职场和发展
碧海蓝天202212 小时前
C++法则24:在标准 C++ 中,没有任何可移植的方式判断指针 T* pt 指向的内存位置是否已经 构造了对象,程序员必须手动跟踪哪些元素已构造。
java·开发语言·c++