【Spring实战】—— 9 AOP环绕通知

来源:互联网 发布:ocr识别软件破解版 编辑:程序博客网 时间:2024/06/05 15:44

假如有这么一个场景,需要统计某个方法执行的时间,如何做呢?

  典型的会想到在方法执行前记录时间,方法执行后再次记录,得出运行的时间。

 

如果采用Spring的AOP,仅仅使用前置和后置方法是无法做到的,因为他们无法共享变量。这样通过环绕通知,就可以快捷的实现。

  首先在切面通知类中声明环绕通知类:


    public void watchPerformance(ProceedingJoinPoint joinpoint){        try{            System.out.println("begin!");            long start = System.currentTimeMillis();                        joinpoint.proceed();                        long end = System.currentTimeMillis();            System.out.println("end!        performance took "+(end-start)+" milliseconds");        }catch(Throwable e){            System.out.println("eee!We want our money back!");        }    }

  在bean.xml配置文件中配置aop:around,锁定方法:

<aop:around pointcut-ref="performance" method="watchPerformance"/>

  这样执行的结果如下:


The audience is taking their seats.The audience is turning off their cellphonesbegin!Instrumentalist age:25Playing Jingle Bells:TOOT TOOT TOOTCLAP CLAP CLAPend!        performance took 95 milliseconds

  因此可以看出AOP执行的过程如下:

  before()  around()  执行方法()  after/throw()  around()
0 0
原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 大麦盒子总自动加软件怎么办 小米手机玩王者荣耀卡怎么办 荣耀8青春版信号差怎么办 华为mate8电池不耐用怎么办 华为4x内存小怎么办 发现手机被用过怎么办 华为p8手机声音小怎么办 手机指纹解锁密码忘了怎么办 华为p10黑色掉漆怎么办 金立手机导航信号弱怎么办 手机导航时gps信号弱怎么办 三星手机导航gps信号弱怎么办 小米5导航信号弱怎么办 华为手机导航gps信号弱怎么办 手机屏玻璃裂了怎么办 oppo音量键坏了怎么办 魅蓝手机屏幕碎了怎么办 手机钢化膜边缘有气泡怎么办 手机贴钢化膜边缘有气泡怎么办 苹果手机钢化膜边缘有气泡怎么办 手机膜里的水泡怎么办 膜贴好了有气泡怎么办 后档玻璃膜气泡怎么办 贴膜里面有灰尘怎么办 贴膜边缘不粘怎么办 贴膜时候的气泡怎么办 贴手机膜起泡了怎么办 手机膜起泡泡了怎么办 手机膜鼓起来了怎么办 贴膜中间有气泡怎么办 新车贴膜有气泡怎么办 贴手机膜进灰尘怎么办 贴手机膜有灰尘怎么办 华为mate10后机壳碎了怎么办 手机屏和壳分开了怎么办 oppoa33手机开不了机怎么办 7p背面刮花了怎么办 oppo手机左右两键失灵怎么办 苹果5s屏幕翘起怎么办 0pp0手机有点卡怎么办 手机用久有点卡怎么办