인터페이스 객체지향에 대해..
324
작성한 질문수 60
김영한님 강의를 듣다보면
객체지향
다형성, 인터페이스
프로시 이런얘기를 많이들었습니다만ㅠㅠ
이해가 안되는거 하나 여쭙고싶네요..
보통 스프링 프로젝트 보면
컨트롤러에 서비스 인터페이스 선언해두고
이를 다시 서비스임플로 구현하자나요
이걸 도대체 왜 하는걸까요?ㅠㅠ
제 생각엔 인터페이스 둔다는것 자체가
구현체를 필요에 따라 갈아끼우겠다는건데..
보통 컨트롤러에 선언해둔 서비스 인터페이스의 의도를 알고싶습니다.,../ㅠㅠㅠ
답변 1
2
안녕하세요, 인프런 AI 인턴입니다.
리어스리님께서 질문하신 “스프링 프로젝트에서 컨트롤러에 서비스 인터페이스를 선언하고 이를 구현체로 구현하는 이유”에 대하여, 김영한 강사님께서 직접 답변해주신 내용이 바로 해결책을 제시할 수 있겠습니다.
이 내용은 본질적으로, 객체지향 프로그래밍의 핵심 원칙 중 하나인 다형성을 활용하는 방법과 밀접하게 관련되어 있습니다. 인터페이스를 사용하는 주된 목적은 구현의 세부 사항을 추상화하여, 사용하는 측에서는 구현의 세부 사항보다는 인터페이스의 계약(또는 API)에만 의존하도록 하여, 향후 구현이 변경되더라도 사용 측 코드에는 영향을 미치지 않도록 하는 것입니다.
다음은 김영한 강사님께서 이러한 질문에 대해 제공한 답변의 일부입니다:
- “Service레이어를 인터페이스로 추상화 하는 이유는 무엇인가요?”에서는 서비스 계층의 인터페이스화가 변경 가능성과 추상화의 비용 사이의 균형을 얻기 위한 것임을 설명합니다. 실무에서는 교체 가능성이 없는 서비스 클래스의 경우 인터페이스를 사용하지 않고 직접 구현체를 사용하기도 하지만, 이상적인 설계에서 역할과 구현을 분리하는 것을 권장합니다.
이 답변에서 핵심은, 인터페이스를 도입하는 것이 추상화라는 비용을 발생시키지만, 기능 확장의 가능성을 열어두기 위해서 또는 명시적인 API 계약을 제공하기 위해 사용될 수 있다는 점입니다. 구현체를 갈아끼울 수 있다는 것은 잠재적인 확장성과 유연성을 의미합니다. 또한, 테스트 용이성도 크게 향상시키는데, 구현체 대신에 인터페이스를 모킹하여 사용할 수 있기 때문입니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.
어드바이스 순서 디폴트 기준이 궁금합니다.
0
52
1
AspectV1 예제를 @Configuration 수동 등록으로도 가능한가요?
0
79
2
구체 클래스를 상속받아 확장한 형태도 클래스패턴/데코레이터 패턴이라고 칭하나요?
0
56
1
TraceTemplate 을 미리 빈으로 등록해서 사용할때 이렇게 설정하는게 맞는건가요?
0
53
1
Decorator 에서 추상메서드로 뺄때 질문 있습니다.
0
56
1
대상 클래스에 기본 생성자가 없을 때
0
75
1
스프링 부트 버전 4.0 aop 의존성 명칭 변경
1
356
2
final 키워드 사용 관련 질문
0
77
1
안녕하세요
0
64
1
ThradLocal 실무 사례
0
97
2
실무에서의 동시성 문제
0
62
1
로그 등 부가 기능에 대한 테스트코드
0
50
1
ProceedingJoinPoint와 MethodInvocation에 대하여
0
67
1
실무 멀티스레딩에 대한 궁금증
0
69
1
안녕하세요 질문있습니다
0
44
1
AspectV3 aop 실행 순서 문의 드립니다
0
38
1
MDC vs AOP 중에 고민중입니다.
0
75
1
순환참조
0
161
2
this를 단독으로 사용할때랑 파라미터 바인딩 할때 차이
0
77
1
빈 후처리에 등록 질문 있습니다.
0
76
1
AppConfig 설정하는 설명중에 이해가 안되는게 있습니다.
0
89
1
ThreadLocal을 지역변수로 선언하면 remove가 필요할까요?
0
117
2
@Aspect 어노테이션으로 생성된 Advisor의 Bean 저장 여부
0
68
1
ThreadLocal 사용시 부작용이 있을수 있을까요? (ThreadLocal.remove()를 잘한다고 해도..)
0
73
2





