关于aop:AOP原理

9次阅读

共计 950 个字符,预计需要花费 3 分钟才能阅读完成。

不批改原代码的前提下,在原性能上减少一个新性能,例如在登陆性能中新增权限性能管制

底层原理:动静代理
两种状况
1)有接口 应用 JDK 动静代理
创立接口实现类代理对象
2)没有接口 应用 CGLIB
创立以后类子类的代理对象

JDK 动静代理实现代码示例

public interface UserDao {public int add(int a, int b);
}
public class UserDaoImpl implements UserDao {

    @Override
    public int add(int a, int b) {
        // TODO Auto-generated method stub
        System.out.println("执行"+a+"+"+b);
        return a+b;
    }

}
public class JdkProxy {public static void main(String[] args) {Class[] interfaces = {UserDao.class};
        UserDaoImpl userDao = new UserDaoImpl();
        UserDao dao = (UserDao)Proxy.newProxyInstance(JdkProxy.class.getClassLoader(), interfaces, new UserDaoProxy(userDao));
        int result = dao.add(1, 2);
    }
}


// 创立代理对象
class UserDaoProxy implements InvocationHandler{
    // 把此次加强的对象传进来
    private Object obj;
    public UserDaoProxy(Object obj) {this.obj = obj;}
    
    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;
    }
}
正文完
 0