Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- kotlin
- http
- java
- 알고리즘
- springdatajpa
- JDBC
- AOP
- spring
- Spring Boot
- transaction
- 인프런
- Exception
- Android
- 스프링 핵심 기능
- 자바
- pointcut
- Thymeleaf
- 백준
- Greedy
- Servlet
- jpa
- 그리디
- QueryDSL
- 스프링 핵심 원리
- JPQL
- SpringBoot
- Proxy
- db
- 스프링
- 김영한
Archives
- Today
- Total
개발자되기 프로젝트
인터페이스기반 프록시와 클래스 기반 프록시 본문
1. 프록시
- 프록시를 사용한 덕분에 원본 코드를 전혀 변경하지 않고, V1, V2 애플리케이션에 LogTrace 기능을
적용할 수 있었다.
2. 인터페이스 기반 프록시 vs 클래스 기반 프록시
- 인터페이스가 없어도 클래스 기반으로 프록시를 생성할 수 있다.
- 클래스 기반 프록시는 해당 클래스에만 적용할 수 있다.
- 인터페이스 기반 프록시는 인터페이스만 같으면 모든 곳에 적용할 수 있다.
- 클래스 기반 프록시는 상속을 사용하기 때문에 몇가지 제약이 있다.
- 부모 클래스의 생성자를 호출해야 한다.(앞서 본 예제)
- 클래스에 final 키워드가 붙으면 상속이 불가능하다.
- 메서드에 final 키워드가 붙으면 해당 메서드를 오버라이딩 할 수 없다.
- 이렇게 보면 인터페이스 기반의 프록시가 더 좋아보인다.
- 맞다. 인터페이스 기반의 프록시는 상속이라는 제약에서 자유롭다.
- 프로그래밍 관점에서도 인터페이스를 사용하는 것이 역할과 구현을 명확하게 나누기 때문에 더 좋다.
- 인터페이스 기반 프록시의 단점은 인터페이스가 필요하다는 그 자체이다.
- 인터페이스가 없으면 인터페이스 기반 프록시를 만들 수 없다.
> 참고: 인터페이스 기반 프록시는 캐스팅 관련해서 단점이 있음..
- 이론적으로는 모든 객체에 인터페이스를 도입해서 역할과 구현을 나누는 것이 좋다. 이렇게 하면 역할과
- 구현을 나누어서 구현체를 매우 편리하게 변경할 수 있다.
- 하지만 실제로는 구현을 거의 변경할 일이 없는 클래스도 많다.
- 인터페이스를 도입하는 것은 구현을 변경할 가능성이 있을 때 효과적인데,
구현을 변경할 가능성이 거의 없는 코드에 무작정 인터페이스를 사용하는 것은 번거롭고
그렇게 실용적이지 않다. - 이런곳에는 실용적인 관점에서 인터페이스를 사용하지 않고 구체 클래스를 바로 사용하는 것이 좋다
(물론 인터페이스를 도입하는 다양한 이유가 있다. 여기서 핵심은 인터페이스가 항상 필요하지는 않다는 것이다.)
3. 결론
- 실무에서는 프록시를 적용할 때 V1처럼 인터페이스도 있고, V2처럼 구체 클래스도 있다.
- 따라서 2가지 상황을 모두 대응할 수 있어야 한다.
4. 너무 많은 프록시 클래스
- 지금까지 프록시를 사용해서 기존 코드를 변경하지 않고, 로그 추적기라는 부가 기능을 적용할 수 있었다.
- 그런데 문제는 프록시 클래스를 너무 많이 만들어야 한다는 점이다.
- 잘 보면 프록시 클래스가 하는 일은 LogTrace 를 사용하는 것인데, 그 로직이 모두 똑같다.
- 대상 클래스만 다를 뿐이다. 만약 적용해야 하는 대상 클래스가 100개라면 프록시 클래스도 100개를 만들어야한다.
- 프록시 클래스를 하나만 만들어서 모든 곳에 적용하는 방법은 없을까?
- 바로 다음에 설명할 동적 프록시 기술이 이 문제를 해결해준다.
'인프런 > [인프런] 스프링 핵심 원리 - 고급' 카테고리의 다른 글
[동적프록시] JDK 동적프록시 - 소개 (0) | 2021.12.30 |
---|---|
[동적프록시] 리플렉션 (0) | 2021.12.30 |
구체 클래스 기반 프록시 - 적용 (0) | 2021.12.30 |
구체 클래스 기반 프록시 - 예제 (0) | 2021.12.29 |
Interface기반 Proxy - 적용 (0) | 2021.12.29 |
Comments