목록전체 글 (796)
코드 그라데이션
자동, 수동의 올바른 실무 운영 기준 편리한 자동 기능을 기본으로 사용하자 고민,,, 그러면 어떤 경우에 컴포넌트 스캔과 자동 주입을 사용하고, 어떤 경우에 설정 정보를 통해서 수동으로 빈을 등록하고, 의존관계도 수동으로 주입해야 할까? 결론부터 이야기하면, 스프링이 나오고 시간이 갈수록 점점 자동을 선호하는 추세 다. 그러면 수동 빈 등록은 언제 사용하면 좋을까? 애플리케이션은 크게 업무 로직과 기술 지원 로직으로 나눌 수 있다. 업무 로직은 숫자도 매우 많고, 한번 개발해야 하면 컨트롤러, 서비스, 리포지토리 처럼 어느정도 유사한 패턴이 있다. 이런 경우 자동 기능을 적극 사용하는 것이 좋다. 보통 문제가 발생해도 어떤 곳에서 문제가 발생했는지 명확하게 파악하기 쉽다. 기술 지원 로직은 업무 로직과 ..
조회한 빈이 모두 필요할 때, List, Map 의도적으로 정말 해당 타입의 스프링 빈이 다 필요한 경우도 있다. 예를 들어서 할인 서비스를 제공하는데, 클라이언트가 할인의 종류(rate, fix)를 선택할 수 있다고 가정해보자. 스프링을 사용하면 소위 말하는 전략 패턴을 매우 간단하게 구현할 수 있다. AllBeanTest.java 생성 package inflearn.spring_core.autowired; import inflearn.spring_core.AutoAppConfig; import inflearn.spring_core.discount.DiscountPolicy; import org.junit.jupiter.api.Test; import org.springframework.beans.fac..
애노테이션 직접 만들기 @Qualifier("mainDiscountPolicy") 이렇게 문자를 적으면 컴파일시 타입 체크가 안된다. 다음과 같은 애노테이션을 만들어서 문제를 해결할 수 있다. annotation 패키지 만들고 MainDiscountPolicy 라는 애노테이션 타입 생성 package inflearn.spring_core.annotation; import org.springframework.beans.factory.annotation.Qualifier; import java.lang.annotation.*; @Target({ElementType.FIELD, ElementType.METHOD, ElementType.PARAMETER, ElementType.TYPE, ElementType.A..
해결 방법은 크게 3가지. 1. @Autowired 필드명 매칭 2. @Qualifier => @Qualifier끼리 매칭 => 빈 이름 매칭 3. @Primary 사용 @Autowired 필드명 매칭 이 생성자를 바꿔준다. 구체적 이름으로 @Autowired public OrderServiceImpl(MemberRepository memberRepository, DiscountPolicy rateDiscountPolicy) { // 여기 변경 this.memberRepository = memberRepository; this.discountPolicy = rateDiscountPolicy; // 여기 변경 } 전체 코드 OrderServiceImpl package inflearn.spring_core...
조회 빈이 2개 이상 - 문제 @Autowired 는 타입(Type)으로 조회한다. @Autowired private DiscountPolicy discountPolicy 타입으로 조회하기 때문에, 마치 다음 코드와 유사하게 동작한다. (실제로는 더 많은 기능을 제공한다.) ac.getBean(DiscountPolicy.class); 스프링 빈 조회에서 학습했듯이 타입으로 조회하면 선택된 빈이 2개 이상일 때 문제가 발생한다. - DiscountPolicy 의 하위 타입인 FixDiscountPolicy , RateDiscountPolicy 둘다 스프링 빈으로 선언해보자. 1. FixDiscountPolicy.java @Component public class FixDiscountPolicy implem..
롬복과 최신 트렌드 막상 개발을 해보면, 대부분이 다 불변이고, 그래서 다음과 같이 필드에 final 키워드를 사용하게 된다. 그런데 생성자도 만들어야 하고, 주입 받은 값을 대입하는 코드도 만들어야 하고… 필드 주입처럼 좀 편리하게 사용하는 방법은 없을까? 다음 기본 코드를 최적화해보자. OrderServiceImpl - 원래 코드 @Component public class OrderServiceImpl implements OrderService { private final MemberRepository memberRepository; private final DiscountPolicy discountPolicy; @Autowired public OrderServiceImpl(MemberReposito..
생성자 주입을 선택해!!! 과거에는 수정자 주입과 필드 주입을 많이 사용했지만, 최근에는 스프링을 포함한 DI 프레임워크 대부분이 생성자 주입을 권장한다. 그 이유는 다음과 같다. 불변 누락 프레임워크 없이 순수한 자바 코드를 단위 테스트 하는 경우에 다음과 같이 수정자 의존관계인 경우 @Component public class OrderServiceImpl implements OrderService { private MemberRepository memberRepository; // final 빼고 private DiscountPolicy discountPolicy; // 이거 두 개 추가 @Autowired public void setMemberRepository(MemberRepository mem..
옵션 처리 주입할 스프링 빈이 없어도 동작해야 할 때가 있다. 그런데 @Autowired 만 사용하면 required 옵션의 기본값이 true 로 되어 있어서 자동 주입 대상이 없으면 오류가 발생한다. 자동 주입 대상을 옵션으로 처리하는 방법은 다음과 같다. AutowiredTest 생성 package inflearn.spring_core.autowired; import inflearn.spring_core.member.Member; import org.junit.jupiter.api.Test; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.context.ApplicationContext; ..