AOP是对方法做了功能加强,相当于用代理的方式重写了原有方法,在调用原有方法时就会执行这里的方法,如果原有方法有返回值,那么这里对应方法需要设置返回值,如下:
@Around("pt()")
public Object runSpeed(ProceedingJoinPoint pjp) throws Throwable {
// 记录程序当前执行(开始时间)
long startTime = System.currentTimeMillis();
// 业务执行方法
Object ret = null;
for (int i = 0; i < 10000; i++) {
ret = pjp.proceed();
}
// 记录程序当前执行时间(结束时间)
long endTime = System.currentTimeMillis();
// 计算时间差
long totalTime = endTime - startTime;
// 输出信息
System.out.println("执行万次消耗时间:" + totalTime + "ms");
return ret;
}
可以查看proceed()方法源码可以看到,其有返回值是Object类型,所以这里使用Object类型,当调用加强的方法时,拿到的结果就是这里返回的ret,是只有一次的。要想打印输出每次原有方法的返回值,在循环里边打印就行了。