aspect 实践

首先,今天没什么事情还加班,唉,老大说我们加班太少,不爽一个。

因为有时间,所以想测试一下我们前几天写的项目执行的效率如何,根据aop应用规范,实现了这么个小功能,具体如下:

一,切面方法类:

/**
 * 分析执行效率
 * @author cyyu
 *
 */
public class AnalysisMqEfficiency {

	public  Object analysis(ProceedingJoinPoint joinPoint) {
		Long start = System.currentTimeMillis();
		Signature s = joinPoint.getSignature();
		String method = s.getName();
		Object[] args = joinPoint.getArgs();
		Object result = null;
		try {
			result = joinPoint.proceed(args);
		} catch (Throwable e) {
			e.printStackTrace();
		}
		Long end = System.currentTimeMillis();
		System.out.println(method+"执行时间:"+(end-start)+"毫秒");
		return result;
	}

二,配置切面

    <bean id="analysis" class="com.service.impl.consumer.AnalysisMqEfficiency"/>
    <aop:config>
        <aop:aspect ref="analysis">
            <aop:pointcut  id="analysisPointcut" expression="execution(* com.service.impl.consumer.JmsConsumerService.*(..))) "/>
            <aop:around method="analysis" pointcut-ref="analysisPointcut"/>
        </aop:aspect>
    </aop:config>


启动tomcat插件,调用JmsConsumerService里面的方法的时候,就可以看到这个类里面每个方法的执行时间了,呵呵。


当然也可以用注解,@aspect,配置 <aop:aspectj-autoproxy/>  ,我觉得xml配置也很方便,懒得去弄了。


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值