今天看了一片文章,讲解如何用java动态代理实现方法的缓存
http://www.matrix.org.cn/article/487.html
看完有以下理解:
首先,他的缓存是针对 InvocationHandler实现对象的一个实例来缓存,而不是全局的。
每一个Memoizer.memoize方法调用,将重新生成一个Memoizer实例。
public static Object memoize(Object object) {
return Proxy.newProxyInstance(
object.getClass().getClassLoader(),
object.getClass().getInterfaces(),
new Memoizer(object)
);
}
方法中object.getClass().getInterfaces()的用法比较灵活,实现了任何对象和接口的动态实例。这也是基于动态代理的aop的实现思想。
http://www.matrix.org.cn/article/487.html
看完有以下理解:
首先,他的缓存是针对 InvocationHandler实现对象的一个实例来缓存,而不是全局的。
每一个Memoizer.memoize方法调用,将重新生成一个Memoizer实例。
public static Object memoize(Object object) {
return Proxy.newProxyInstance(
object.getClass().getClassLoader(),
object.getClass().getInterfaces(),
new Memoizer(object)
);
}
方法中object.getClass().getInterfaces()的用法比较灵活,实现了任何对象和接口的动态实例。这也是基于动态代理的aop的实现思想。