작성
·
237
0
public class AppConfig {
public static memberRepository() {
return new MemoryMemberRepository();
}
public MemberService memberService() {
return new MemberServiceImpl();
}
}
public class MemberServiceImpl implements MemberService {
private final MemberRepository memberRepository = AppConfig.memberRepository();
@Override
public void register(Member member) {
memberRepository.save(member);
}
@Override
public Member findMemberBy(Long memberId) {
return memberRepository.findById(memberId);
}
}
답변 1
4
안녕하세요. 강민주님, 공식 서포터즈 David입니다.
작성하신 것은 다른 객체를 통해 의존관계인 객체를 생성하는 관점에는 괜찮지만 MemberServiceImpl이 AppConfig에 의존하게 됩니다.
생성자 주입을 이용하면 MemberServiceImpl이 AppConfig에 의존하지 않고 MemberRepository를 주입받을 수 있습니다. 즉, 불필요한 의존관계를 가질 필요가 없다는 말입니다. 굳이 예를 들어 보자면 AppConfig가 아닌 다른 설정 클래스(AppConfig2)로부터 MemberRepository를 주입 받아야 하는 상황이 있다면 AppConfig에 의존하고 있는 MemberServiceImpl은 수정대상이 됩니다.
감사합니다.
저도 이 생각을 했었는데 David님이 주신 답변으로 의문점이 해결되었습니다.
코드를 작성하면서 느끼는거지만 인터페이스가 내부적으로 동작에 필요한 역활을 주고 역활을 수행할 객체는 어플리케이션에서 실행시킬때 주입시켜 동작하는 형태을 하는것 같아요
그렇게 될려면 클라이언트 코드에는 구현 아닌 인터페이스에 의존하는 코드가 나와야하고 저 코드에서 의존 관계를 해결하기위해서는 생성자 주입 통해서 해결이 가능해보여요