今天看了一片文章,讲解如何用java动态代理实现方法的缓存
http://www.matrix.org.cn/article/487.html
看完有以下理解:
首先,他的缓存是针对 InvocationHandler实现对象的一个实例来缓存,而不是全局的。
每一个Memoizer.memoize方法调用,将重新生成一个Memoizer实例。
publicstaticObjectmemoize(Objectobject){
returnProxy.newProxyInstance(
object.getClass().getClassLoader(),
object.getClass().getInterfaces(),
newMemoizer(object)
);
}
方法中object.getClass().getInterfaces()的用法比较灵活,实现了任何对象和接口的动态实例。这也是基于动态代理的aop的实现思想。
http://www.matrix.org.cn/article/487.html
看完有以下理解:
首先,他的缓存是针对 InvocationHandler实现对象的一个实例来缓存,而不是全局的。
每一个Memoizer.memoize方法调用,将重新生成一个Memoizer实例。
publicstaticObjectmemoize(Objectobject){
returnProxy.newProxyInstance(
object.getClass().getClassLoader(),
object.getClass().getInterfaces(),
newMemoizer(object)
);
}
方法中object.getClass().getInterfaces()的用法比较灵活,实现了任何对象和接口的动态实例。这也是基于动态代理的aop的实现思想。
文章介绍了用Java动态代理实现方法缓存的内容。其缓存是针对InvocationHandler实现对象的实例,非全局的。每次调用Memoizer.memoize方法会生成新的Memoizer实例,还提到方法中object.getClass().getInterfaces()用法灵活,体现了基于动态代理的AOP实现思想。
364

被折叠的 条评论
为什么被折叠?



