- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
Spring AOP 使用动态代理技术在运行期织入增强的代码,为了揭示Spring AOP 底层的工
作机理,有必要对涉及到的Java 知识进行学习。Spring AOP 使用了两种代理机制:一种
是基于JDK 的动态代理;另一种是基于CGLib 的动态代理。之所以需要两种代理机制,很
大程度上是因为JDK 本身只提供接口的代理,而不支持类的代理。
带有横切逻辑的实例
我们通过具体化代码实现上一节所介绍例子的性能监视横切逻辑,并通过动态代理技术对此
进行改造。在调用每一个目标类方法时启动方法的性能监视,在目标类方法调用完成时记录
方法的花费时间。
代码清单6-2 ForumService:包含性能监视横切代码
Java 代码
1. package com.baobaotao.proxy;
2. public class ForumServiceImpl implements ForumService {
3. public void removeTopic(int topicId) {
4.
5. //①-1 开始对该方法进行性能监视
6. PerformanceMonitor.begin(
7. com.baobaotao.proxy.ForumServiceImpl. removeTop
ic);
8. System.out.println(模拟删除Topic 记录:+topicId);
9. try {
10. Thread.currentThread().sleep(20);
11. } catch (Exception e) {
12. throw new RuntimeException(e);
13. }
14.
15. //①-2 结束对该方法进行性能监视
16. PerformanceMonitor.end();
17. }
18.
19. public void removeForum(int forumId) {
20. //②-1 开始对该方法进行性能监视
21. PerformanceMonitor.begin(
22. com.baobaotao.proxy.ForumServiceImpl. removeForum);
23. System.out.println(模拟删除Forum 记录:+forumId);
24. try {
25. Thread.currentThread().sleep(40);
26. } catch (Exception e) {
27. throw new RuntimeException(e);
28. }
29.
30. //②-2 结束对该方法进行性能监视
31. PerformanceMonitor.end();
32. }
33. }
代码清单6-2 中粗体表示的代码就是具有横切逻辑特征的代码,每个Service 类和每个业务
方法体的前后都执行相同的代码逻辑:方法调用前启动PerformanceMonitor,方法调用后
通知PerformanceMonitor 结束性能监视并给记录性能监视结果。
PerformanceMonitor 是性能监视的实现类,我们给出一个非常简单的实现版本,其代码如
代码清单6-3 所示:
代码清单6-3 PerformanceMonitor
Java 代码
1. package com.baobaotao.proxy;
2. public class PerformanceMonitor {
3. //①通过一个ThreadLocal 保存调用线程相关的性能监视信息
4. private static ThreadLocalMethodPerformace p
文档评论(0)