inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

스프링 핵심 원리 - 기본편

AppConfig 리팩터링

서비스 로케이터 패턴

449

Olive

작성한 질문수 4

4

안녕하세요. 선생님. 좋은 강의 만들어주셔서 감사합니다^^

추천해주신 조영호님의 책들을 보면서 객체지향을 추가적으로 공부하면서 강의를 듣고 있습니다.

강의에서 AppConfig 를 이용해 의존성을 해결하는 방식을 일종의 SERVICE LOCATOR 패턴이라고 봐도 되나요??

아니라면 예를 들어 MemberServiceImpl 의 생성자를 이런식으로 작성하는 경우가 SERVICE LOCATOR 패턴이 될까요?

public MemberServiceImpl(){
    this.memberRepository = AppConfig.memberRepository();
}

결국 클라이언트 입장에서는  전부 비슷하다고 느껴지는데 헷갈려서 질문드립니다.

oop spring

답변 1

5

김영한

안녕하세요. Olive님^^

예를 들어서 MemberServiceImpl이 MemberRepository 인터페이스에만 의존하고 싶고, 구체적인 구현클래스는 서비스 로케이터를 통해서 제공 받으면 향후 구현클래스의 변경이 일어날 때 서비스 로케이터만 변경하면 되고, 클라이언트인 MemberServiceImpl은 변경하지 않아도 됩니다. 클라이언트 관점에서 구체 클래스의 선택을 AppConfig에 위임하는 것이기 때문에 AppConfig를 직접 사용하는 것도 서비스 로케이터 패턴이라 할 수 있습니다.

서비스 로케이터는 단순히 클라이언트 입장에서 객체를 찾아오는 방법을 서비스 로케이터를 통해서 위임하는 것으로 이해하시면 됩니다. 이렇게 해도 클라이언트인 MemberServiceImpl 입장에서는 MemberRepository에만 의존할 수 있습니다.

그런데 이런 서비스 로케이터를 사용하는 단점은 클라이언트가 서비스 로케이터를 알아야 한다는 것입니다. DI를 사용하면 서비스 로케이터 조차도 몰라도 됩니다.

감사합니다.

구현체가 동적으로 정해질 때, 팩토리 기법을 사용하나요?

0

49

2

MemberService의 인터페이스를 왜 사용하는지 궁금합니다.

0

72

1

롬복 @Setter를 써야 하는 상황이 있는건가요?

0

87

1

빈 등록 메서드의 파라미터가 빈이 아니어도 되나요?

0

79

1

테스트 속도가 나중에 영향이 있을까요?

0

75

1

gradle 설정 안떠서 질문 남깁니다!

0

117

2

build.gradle로 프로젝트를 여는 이유

0

81

1

provider 사용하는 이유

0

85

1

다음 강의 뭘 들어야 할까요

0

123

2

프로토타입 빈, 직접 destroy 호출 안 할 경우

0

62

1

beanB

0

79

2

퀴즈다시풀기

0

63

1

Gradle로 바꿔도 오류가 똑같이 발생하네요 ㅠㅠ

0

90

2

"중복 등록과 충돌" 강의에서 강사님과 다른 에러가 발생합니다.

0

63

3

run 실행했는데 결과창이 이렇게 뜨네요 왜 그런건가요>

0

102

2

도메인의 정의?

0

57

1

ApplicationContext 질문입니다.

0

60

1

@Scope의 proxyMode를 사용할때 단위 테스트 방법

0

86

2

ai api 선정하기 관련 질문

0

116

2

생성자 자동주입 관련해서

0

61

1

생성자 직접 호출 vs 팩토리 메서드 패턴

0

93

2

Spring에서 SessionScope와 RequestScope는 함께 사용되나요?

1

63

1

12:25

0

75

2

appConfig.xml 오류

0

127

1