AOP底层原理以及JDK动态代理

本文探讨了面向切面编程(AOP)的概念,如何利用动态代理(JDK与CGLIB)实现在不修改源代码情况下添加新功能。通过登录示例和JDK动态代理代码详解,揭示了AOP在实际开发中的应用和底层原理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

AOP(概念)
1、什么是AOP
(1)面向切面编程(方面)
利用AOP可以对业务逻辑的各个部分进行隔离,从而使得业务逻辑各部分之间的耦合度降低,提高程序的可复用性,同时也提高了程序开发的效率。
(2)通俗描述:不通过修改源代码方式,再主干功能里面添加新功能

在这里插入图片描述
(3)使用登录例子说明AOP

AOP(底层原理)

1、AOP底层使用动态代理
(1)有两种情况动态代理
(代理就是创建被增强对象的代理对象,通过代理对象实现功能)
第一种 有接口情况,使用JDK动态代理
创建接口实现类的代理对象,增强类的方法
在这里插入图片描述

第二章 没有接口情况,使用CGLIB动态代理
创建当前类子类的代理对象,增强类的方法
在这里插入图片描述

AOP(JDK动态代理)

1、使用JDK动态代理,使用Proxy类里面的方法创建代理对象
在这里插入图片描述
(1)调用 newProxyInstance方法
在这里插入图片描述
方法有三个参数:
第一个参数:ClassLoader 类加载器
interfaces 增强方法所在的类,这个类实现的接口,支持多个接口
实现这个接口InvocationHandler,创建代理对象,写增强的方法
2、JDK动态代理代码
(1)创建接口,定义方法

public interface UserDao {
    public int add(int a, int b);
    public String update(String id);
}

(2)创建接口实现类,实现方法

package com.atguigu.spring5.collectiontype;

public class UserDaoImpl implements  UserDao{
    @Override
    public int add(int a, int b) {
        return a+b;
    }

    @Override
    public String update(String id) {
            return id;
    }
}

(3)使用Proxy类创建接口代理对象

package com.atguigu.spring5.collectiontype;

import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy;
import java.util.Arrays;

public class JDKProxy {
    public static void main(String[] args){
        //创建接口实现类代理对象
        Class[] interfaces = {UserDao.class};
//        Proxy.newProxyInstance(JDKProxy.class.getClassLoader(), interfaces, new InvocationHandler() {
//            @Override
//            public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
//                return null;
//            }
//        })
        UserDaoImpl userDao = new UserDaoImpl();

        Object dao = (UserDao)Proxy.newProxyInstance(JDKProxy.class.getClassLoader(), interfaces, new UserDaoProxy(userDao));
        int result = ((UserDao) dao).add(1,2);
        System.out.println("result:"+result);
    }
}
//创建代理对象代码

class  UserDaoProxy implements InvocationHandler{
    //1 把创建的是谁的代理对象,把那个谁传递过来
    //有参数构造传递
    private Object obj;
    public UserDaoProxy(Object obj){
        this.obj = obj;
    }



    //增强的逻辑
    @Override
    public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
        //方法之前处理
        System.out.println("在方法之前执行。。。。"+method.getName()+":传递的参数。。。"+ Arrays.toString(args));
        //被增强的方法执行
        Object res = method.invoke(obj, args);
        //方法之后处理
        System.out.println("方法之后执行...."+obj);
        return res;
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

SCU Polars

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值