JoinPoint.getThis() 반환값
517
投稿した質問数 11
JoinPoint.getThis() 반환값을 출력해보니
Target 객체가 나오는 것 같습니다..
JoinPoint.getTarget() 과 동일한 값이 나옵니다.
getThis() 하면 proxy 객체가 나와야 될 것 같은데,
(예제에서는 interface 가 없는 구현체이므로, CGLIB 객체)
Target 객체가 나오는 이유가 있을 까요?
@Before("hello.aop.order.aop.Pointcuts.orderAndService()")
public void doBefore(JoinPoint joinPoint) {
log.info("[before] {}", joinPoint.getSignature());
log.info("[before this] {}", joinPoint.getThis());
log.info("[before target] {}", joinPoint.getTarget());
}
2022-06-28 22:04:55.928 INFO 1765 --- [ Test worker] hello.aop.order.aop.AspectV6Advice : [before this] hello.aop.order.OrderService@f171912
2022-06-28 22:04:55.929 INFO 1765 --- [ Test worker] hello.aop.order.aop.AspectV6Advice : [before target] hello.aop.order.OrderService@f171912
감사합니다.
回答 2
1
안녕하세요! 시간이 지나서 궁금증을 해소하셧을지 모르지만 혹시나 해서 남겨봅니다!


위 이미지를 확인해보시면 getThis()와 getTarget()이 같은 OrderService를 가리키고 있지만 getClass()의 경우 원하던 CBLIB를 가리킵니다.
[aspectJ 공식문서](https://www.eclipse.org/aspectj/doc/released/runtime-api/org/aspectj/lang/JoinPoint.html#getTarget())를 확인하시면 getThis()의 경우 현재 실행중인 개체를 가리키기 때문에 현재 속에 있는 OrderService를 보여주고, getThis().getClass()를 하였을 때 해당 프록시 클래스를 보여준다고 생각했습니다.
어드바이스 순서 디폴트 기준이 궁금합니다.
0
50
1
AspectV1 예제를 @Configuration 수동 등록으로도 가능한가요?
0
77
2
구체 클래스를 상속받아 확장한 형태도 클래스패턴/데코레이터 패턴이라고 칭하나요?
0
49
1
TraceTemplate 을 미리 빈으로 등록해서 사용할때 이렇게 설정하는게 맞는건가요?
0
53
1
Decorator 에서 추상메서드로 뺄때 질문 있습니다.
0
55
1
대상 클래스에 기본 생성자가 없을 때
0
74
1
스프링 부트 버전 4.0 aop 의존성 명칭 변경
1
341
2
final 키워드 사용 관련 질문
0
74
1
안녕하세요
0
64
1
ThradLocal 실무 사례
0
97
2
실무에서의 동시성 문제
0
62
1
로그 등 부가 기능에 대한 테스트코드
0
50
1
ProceedingJoinPoint와 MethodInvocation에 대하여
0
66
1
실무 멀티스레딩에 대한 궁금증
0
69
1
안녕하세요 질문있습니다
0
43
1
AspectV3 aop 실행 순서 문의 드립니다
0
37
1
MDC vs AOP 중에 고민중입니다.
0
74
1
순환참조
0
158
2
this를 단독으로 사용할때랑 파라미터 바인딩 할때 차이
0
77
1
빈 후처리에 등록 질문 있습니다.
0
75
1
AppConfig 설정하는 설명중에 이해가 안되는게 있습니다.
0
88
1
ThreadLocal을 지역변수로 선언하면 remove가 필요할까요?
0
116
2
@Aspect 어노테이션으로 생성된 Advisor의 Bean 저장 여부
0
67
1
ThreadLocal 사용시 부작용이 있을수 있을까요? (ThreadLocal.remove()를 잘한다고 해도..)
0
72
2

