
目录
-
- 什么是动态代理
- 实现动态代理的关键步骤
- 动态代理的优点
- 代码解析
什么是动态代理
- 这个代理就相当于是劳工, 帮我们去做我们能做到, 但是不想做的事情, 比如搬砖…
- 动态代理是面向切面编程的核心思想
- 他是对我们的方法进行代理
实现动态代理的关键步骤
- 必须要有一个接口, 因为代理通常是基于接口实现的
- 创建一个该接口的实现类, 我们把这个实现类称为业务对象, 我们的代理就是代理这个业务对象, 对该业务对象中的方法进行功能上的增强
- 执行该业务类中的方法的时候, 我们首先会走代理, 代理中会通过反射, 获取我们业务类中的方法, 然后在该方法的前后实习功能的增强.
动态代理的优点
- 非常灵活, 可以对任意类型的接口的实现类做代理, 也可以对接口本身做代理, 进行功能上的增强
- 本质就是通过反射来侵入到类的方法内部, 对该方法进行代码上的增强
- 可以为被代理类的所有方法都做代理, 我们只要调用该类的方法, 就会 走动态代理.
- 在不改变源码的情况下, 实现对代码的增强
代码解析
public static<T> T getProc(T obj) {return (T) Proxy.newProxyInstance(obj.getClass().getClassLoader(), obj.getClass().getInterfaces(),new InvocationHandler() {@Overridepublic Object invoke(Object proxy, Method method, Object[] args) throws Throwable {long st = System.currentTimeMillis();Object result = method.invoke(obj, args);long et = System.currentTimeMillis();long time = et - st;System.out.println(method.getName() + "方法所消耗时间" + time);return result;}});}
public static void main(String[] args) throws InterruptedException {UserService2 userService = Proxy_Util.getProc(new UserServiceImpl2());userService.delete();userService.update();System.out.println(userService.add("admin", "123"));}
public interface UserService {boolean add(String name, String password);void update();void delete();
}
public class UserServiceImpl implements UserService {@Overridepublic boolean add(String name, String password) {long st = System.currentTimeMillis();if("admin".equals(name) && "123".equals(password)) {System.out.println("登录成功");try {Thread.sleep(1000);} catch (InterruptedException e) {e.printStackTrace();} finally {long et = System.currentTimeMillis();long rs = et - st;System.out.println("add方法所消耗时间: " + rs);}return true;}return false;}@Overridepublic void update() {long st = System.currentTimeMillis();System.out.println("修改了100个信息。。。。");try {Thread.sleep(2000);} catch (InterruptedException e) {e.printStackTrace();} finally {long et = System.currentTimeMillis();long rs = et - st;System.out.println("update方法所消耗时间: " + rs);}}@Overridepublic void delete() {long st = System.currentTimeMillis();System.out.println("删除了100个信息。。。。");try {Thread.sleep(2000);} catch (InterruptedException e) {e.printStackTrace();} finally {long et = System.currentTimeMillis();long rs = et - st;System.out.println("delete方法所消耗时间: " + rs);}}
}