注釈(春の起動アプリケーションで)注釈を書き込んで、call()
メソッドCallable
に適用しようとしましたが、それでもまだ動作しません。通常の方法(下記のコードを参照してください)、それは動作します、これは私を悩ませ続ける、あなたは私にいくつかの手がかりをくれますか?どうもありがとうございました。ここでJavaの注釈がCallableで機能しない
が@sbjavateamに触発さ
@Target(ElementType.METHOD)
@Retention(RetentionPolicy.RUNTIME)
public @interface LogExecutionTime {
}
@Aspect
@Component
public class LogExecutionTimeAspect {
private static final Logger logger = LoggerFactory.getLogger(LogExecutionTimeAspect.class);
@Around("@annotation(LogExecutionTime)")
public Object logExecutionTime(ProceedingJoinPoint joinPoint) throws Throwable {
final long start = System.currentTimeMillis();
final Object proceed = joinPoint.proceed();
final long executionTime = System.currentTimeMillis() - start;
logger.info(joinPoint.getSignature() + " executed in " + executionTime + "ms");
return proceed;
}
}
public class DummyCallable implements Callable<Integer> {
private Integer start, count;
DummyCallable() {}
DummyCallable(Integer start, Integer count) {
this.start = start;
this.count = count;
}
@LogExecutionTime // not working...
@Override
public Integer call() throws Exception {
Thread.sleep(start * 1000);
Integer sum = 0;
for (Integer i = start; i <= start + count; i++) {
sum += i;
}
return sum;
}
}
@LogExecutionTime // This will work...
public List<Integer> getAllUserScores() {
Callable c1 = new DummyCallable(1, 100000);
Callable c2 = new DummyCallable(2, 100000);
Callable c3 = new DummyCallable(3, 100000);
// .... run them ...
return result;
}
春はプロキシを使用し、オブジェクトへのメソッド呼び出しだけがインターセプトされます。内部的にメソッドを呼び出しています。 –