안녕하세요
515
작성한 질문수 24
경력이 5년이 넘었는데도, 스프링을 쓸줄만 알지 이해도는 낮다고 생각되어 수강하고있는 개발자입니다.
예전부터 궁금하다가 답을 못찾고, 이번 강의를 보면서 제가 생각했던게 맞았지만, 과연 이것때문에 모든 코드를 이렇게 구현할까? 라는 의문점이 들어 여쭤보려 하는데요.
서비스를 구현할 때 인터페이스, 구현체로 하는 이유가 있을까요? 실무에서 항상 XXXservice, XXXserviceImpl로 업무를 했는데요. 인터페이스를 사용하며 구현체를 바꿔사용하는것은 이해됩니다.
CarService을 확장한 ToyotaImpl, KiaImpl등등을 그에 맞게 확장가능한거는 이해가 되는데... 굳이 이 이유 하나만으로 인터페이스를 사용하는지 좀 궁금해서요.
답변 1
8
안녕하세요. zergcity님
인터페이스를 사용하는 가장 큰 목적은 선언과 구현을 분리하기 위함입니다. 그래서 사용하는 입장에서 인터페이스만 의존하고, 구현을 모르도록 하는 것이지요. 그래야 향후 구현을 변경했을 때 클라이언트 코드를 변경하지 않아도 되기 때문입니다.
바꾸어 말씀드리자면, 변경할 이유가 전혀 없다면, 인터페이스를 사용하지 않는 것도 좋은 방법입니다.
인터페이스를 사용하게되면 추상화를 하게 되는데, 결과적으로 추상화도 개발 코드를 이해하기 어렵게 만드는 비용입니다.
저의 경우에도 실무에서 전혀 변경할 이유가 없는 코드들은 인터페이스를 사용하지 않습니다.
서비스 클래스들도 마찬가지입니다.
추가로 과거에는 인터페이스가 없으면 AOP를 적용할 수 없었는데, 지금은 이런 부분도 어느정도 다 해결되어서 인터페이스가 없어도 AOP를 사용할 수 있습니다.
감사합니다.
구현체가 동적으로 정해질 때, 팩토리 기법을 사용하나요?
0
46
2
MemberService의 인터페이스를 왜 사용하는지 궁금합니다.
0
72
1
롬복 @Setter를 써야 하는 상황이 있는건가요?
0
87
1
빈 등록 메서드의 파라미터가 빈이 아니어도 되나요?
0
79
1
테스트 속도가 나중에 영향이 있을까요?
0
75
1
gradle 설정 안떠서 질문 남깁니다!
0
116
2
build.gradle로 프로젝트를 여는 이유
0
81
1
provider 사용하는 이유
0
83
1
다음 강의 뭘 들어야 할까요
0
123
2
프로토타입 빈, 직접 destroy 호출 안 할 경우
0
62
1
beanB
0
79
2
퀴즈다시풀기
0
63
1
Gradle로 바꿔도 오류가 똑같이 발생하네요 ㅠㅠ
0
90
2
"중복 등록과 충돌" 강의에서 강사님과 다른 에러가 발생합니다.
0
63
3
run 실행했는데 결과창이 이렇게 뜨네요 왜 그런건가요>
0
102
2
도메인의 정의?
0
57
1
ApplicationContext 질문입니다.
0
60
1
@Scope의 proxyMode를 사용할때 단위 테스트 방법
0
86
2
ai api 선정하기 관련 질문
0
115
2
생성자 자동주입 관련해서
0
60
1
생성자 직접 호출 vs 팩토리 메서드 패턴
0
92
2
Spring에서 SessionScope와 RequestScope는 함께 사용되나요?
1
62
1
12:25
0
74
2
appConfig.xml 오류
0
124
1





