如果我们使用嵌套调用重载方法,如下所示
public void sample(int a) {
sample(a, 5);
}
public void sample(int a, int offset) {
System.out.println(a + offset);
}
下面是一个切入点和建议
@Pointcut("execution(public * sample*(..))")
public void sampleMethod() {}
@Around("sampleMethod()")
public Object storeMetrics(final ProceedingJoinPoint jp) throws Throwable {
System.out.println("Advice called");
}
现在,如果调用sample(10),我得到的“建议调用”是输出的两倍。这是否意味着切入点截获了两个重载的方法?
但是考虑一下方法没有重载的情况,如下所示。现在,即使两个方法都与切入点表达式匹配,它也只输出一次“通知调用”
public void sample(int a) {
sampleWithOffset(a, 5);
}
public void sampleWithOffset(int a, int offset) {
System.out.println(a + offset);
}
@Pointcut("execution(public * sample*(..))")
public void sampleMethod() {}
@Around("sampleMethod()")
public Object storeMetrics(final ProceedingJoinPoint jp) throws Throwable {
System.out.println("Advice called");
}
发布于 2018-05-31 09:02:58
首先,您的@Around
方面不会编译,因为它不返回结果。您可能忘记了从代码中复制return jp.proceed();
之类的内容。
现在,如果调用
(10),我得到的“建议调用”是输出的两倍。这是否意味着切入点截获了两个重载的方法?
当然,因为您的切入点同时匹配两个方法名。如果你想要不同的行为,改变你的切入点。
,但请考虑方法没有重载的情况,如下所示。现在,即使两个方法都与切入点表达式匹配,它也只输出一次“通知调用”
你的陈述是错误的。方面也打印两次。以下是证据:
驱动程序:
package de.scrum_master.app;
public class Application {
public void sample(int a) {
sample(a, 5);
sampleWithOffset(a, 9);
}
public void sample(int a, int offset) {
System.out.println(a + offset);
}
public void sampleWithOffset(int a, int offset) {
System.out.println(a + offset);
}
public static void main(String[] args) {
new Application().sample(11);
}
}
方面:
package de.scrum_master.aspect;
import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.Around;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Pointcut;
@Aspect
public class MyAspect {
@Pointcut("execution(public * sample*(..))")
public void sampleMethod() {}
@Around("sampleMethod()")
public Object storeMetrics(final ProceedingJoinPoint jp) throws Throwable {
System.out.println(jp);
return jp.proceed();
}
}
控制台日志:
execution(void de.scrum_master.app.Application.sample(int))
execution(void de.scrum_master.app.Application.sample(int, int))
16
execution(void de.scrum_master.app.Application.sampleWithOffset(int, int))
20
https://stackoverflow.com/questions/50590884
复制相似问题