不批改原代码的前提下,在原性能上减少一个新性能,例如在登陆性能中新增权限性能管制
底层原理:动静代理
两种状况
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; }}