해결된 질문
작성
·
471
1
바로 전 강의에서 영한님께서 스프링 컨테이너에 등록된 똑같은 타입을 가지고 있는 스프링 빈이 두개 이상일 때 타입으로 조회시 에러가 난다고 말씀하셨고
이떄 하위 타입으로 지정할 수 있지만, 하위 타입으로 지정하는 것은 DIP를 위배한다고 하셨습니다.
그래서 이번 강의에서 3가지 해결법을 알려주셨는데
@Autowired 필드 명 또는 파라미터 이름 매칭에서 OrderServiceImpl 코드가 이렇게 변하는데 그럼 OCP도 위배하면서 rateDiscountPolicy라는 구체화 된 것을 주입할 때(파라미터 이름으로 같은 이름의 스프링 빈을 찾기 위함은 알고 있습니다.) DIP를 같이 위배하는 것이지 않나요?
답변 1
5
안녕하세요. Lego님, 공식 서포터즈 David입니다.
해당 코드에서는 여전히 DiscountPolicy라는 고수준 모듈에 의존하고 있으므로 DIP 위반으로 볼 수는 없을 것 같습니다.
또한 절반만 OCP를 위반하고 있다 생각합니다. 그 이유는 파라미터 명 매칭을 통해 주입하는 것은 스프링에서 지원하는 기능이지만 해당 기능과 별개로 DiscountPolicy의 다른 구현체를 주입하여 기능을 확장할 수 있기 때문입니다.
예를 들어, 스프링을 사용하지 않고 OrderServiceImpl을 생성할 때 파라미터가 DiscountPolicy rateDiscountPolicy로 되어 있을 때 파라미터 명과 상관없이 FixedDiscountPolicy를 넘기든 RateDiscountPolicy를 넘기든 정상적으로 동작합니다. DiscountPolicy타입의 파라미터명이 rateDiscountPolicy로 되어 있는 게 어색하지만요.
다만, 스프링에서 제공하는 기능을 통해 파라미터 명을 변경하여 구현체를 변경한다면 OCP를 위반하게 됩니다.
감사합니다.