@Qualifier("mainDiscountPolicy") 이렇게 문자를 적으면 컴파일시 타입 체크가 안된다.
다음과 같은 애노테이션을 만들어서 문제를 해결할 수 있다
@Target({ElementType.FIELD, ElementType.METHOD, ElementType.PARAMETER,
ElementType.TYPE, ElementType.ANNOTATION_TYPE})
@Retention(RetentionPolicy.RUNTIME)
@Documented
@Qualifier("mainDiscountPolicy")
public @interface MainDiscountPolicy {
}
@Component
//@Qualifier("mainDiscountPolicy")//문자기 때문에 컴파일 타임에 오류를 잡을 수 없다
@MainDiscountPolicy
public class RateDiscountPolicy implements DiscountPolicy{
//생성자 자동 주입
@Autowired
public OrderServiceImpl(MemberRepository memberRepository, @MainDiscountPolicy DiscountPolicy discountPolicy) { this.memberRepository = memberRepository; this.discountPolicy = discountPolicy; }
//수정자 자동 주입
@Autowired
public DiscountPolicy setDiscountPolicy(@MainDiscountPolicy DiscountPolicy discountPolicy) {
this.discountPolicy = discountPolicy; }
애노테이션에는 상속이라는 개념이 없다. 이렇게 여러 애노테이션을 모아서 사용하는 기능은 스프링이 지원해주는 기능이다. @Qulifier 뿐만 아니라 다른 애노테이션들도 함께 조합해서 사용할 수 있다.
단적으로 @Autowired도 재정의 할 수 있다. 물론 스프링이 제공하는 기능을 뚜렷한 목적 없이 무분별하게 재정의 하는 것은 유지보수에 더 혼란만 가중할 수 있다.
'스프링' 카테고리의 다른 글
7/6 스프링 핵심원리 - 자동, 수동의 올바른 실무 운영 기준 (0) | 2022.07.09 |
---|---|
스프링 핵심 원리 - 조회한 빈이 모두 필요할 때, List , Map (0) | 2022.07.09 |
7/6 스프링 핵심원리 - 조회빈이 2개이상 (0) | 2022.07.09 |
7/6 스프링 핵심원리 - 롬복과 최신 트렌드 (0) | 2022.07.09 |
스프링 핵심원리 - 옵션처리 , 생성자 주입 선택 (0) | 2022.07.09 |