해결된 질문
작성
·
731
답변 2
3
말씀하신 거 처럼
MemberService memberService = new MemberService();
로 하시면 아래 그림처럼 오류가 뜰 겁니다.
임포트 받아온 MemberService는 인터페이스라
인스턴스화 될 수 없기 때문입니다.
(인터페이스는 생성자를 갖을 수 없습니다)
저렇게 A a = new B( ); 가 되는 이유는
다형성 때문입니다.
다형성에 관한 내용은 여기를 참조해주세요.
https://wikidocs.net/269
만약 비지니스 요구사항이 인터페이스를
안써도 되고, MemberService가 클래스였다면
1번 질문의 코드도 물론 가능합니다.
MemberService memberService = new MemberService();
반대로 테스트만을 위해서라면 아래처럼 해도
오류는 나지 않습니다만 OCP 관점으로 봤을때는
추천되진 않을 거 같습니다....
MemberServiceImpl memberService = new MemberServiceImpl();
그럼 자료형으로 인터페이스와 구현체 중
언제 뭘 쓰느냐는...
기본적으로는 인터페이스라고 알고 있습니다.
서포터스 David님이 다른 질문에서 답글로 공유하신 글 입니다.
https://github.com/david-learner/java-study/tree/master/2018OKKYCON#%EC%84%A4%EA%B3%84
"테스트를 할 때 구현(implementation)이 아니라 설계(interface)에 맞춰야 한다"
다만, 객체가 인터페이스에 의존하지 않고 특정(구체적인) 구현체에 의존하고 있다면 해당 구현체를 테스트해야 하는 일이 있을 수 있습니다.
틀린 점 있으면 피드백 부탁드립니다!
3