inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

스프링 핵심 원리 - 기본편

싱글톤 패턴

getInstance()와 DIP

600

진진

작성한 질문수 3

0

[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예)

[질문 내용]
싱글톤은 DIP를 위반한다는 설명에서

(기존)

public MemberService memberService(){

return new MemberServiceImpl(memberserviceRepository());

}

(싱글톤 패턴 적용 시)

public MemberService memberService(){

return MemberServiceImpl.getInstance();

}

에서 구체 클래스에 의존하기 때문에 DIP를 위반한다고 하셨습니다.

 

하지만 AppConfig에는 객체 인스턴스를 연결하기 위해 어차피 구체클래스를 사용하는데, DIP를 위반한다고 하는 이유가 뭔지 궁금합니다!

 

 

spring 객체지향

답변 1

3

김영한

안녕하세요. 진진님

클라이언트 코드가 구체 클래스에 직접 의존하게 되면 DIP를 위반하게 됩니다.

예를 들어서 클라이언트 코드인 MemberController 코드에서 싱글톤 코드인 MemberServiceImpl.getInstance()를 직접 호출하게 되면 MemberController는 MemberServiceImpl이라는 구체 클래스에 직접 의존하게 됩니다.

향후 MemberServiceImpl을 다른 클래스로 변경해야 할 때 클라이언트 코드인 MemberController의 코드도 변경해야 하는 것이지요.

 

3 스프링 핵심 원리 이해2 - 객체 지향 원리 적용에서 설명드린 것 처럼 사용 영역구성 영역을 구분해야 합니다. 결국 AppConfig같은 누군가는 구체 클래스를 사용하는 지저분한 일을 대신 해주어야 합니다.

구성 영역인 AppConfig는 당연히 구체적인 코드를 알아야 합니다. 구성 영역은 애플리케이션 전체를 조망하고 조립하는 역할을 하기 때문에 이 부분은 구체 클래스를 사용해야 합니다.

덕분에 사용 영역에 있는 코드들을 구체 코드를 몰라도 깔끔함을 유지할 수 있습니다. 그런데 클라이언트 코드인 MemberController가 싱글톤 코드에 직접 의존하게 되면 DIP를 위반하게 된다는 것입니다.

관련해서 2,3에서 설명드린 스프링 핵심 원리 이해 부분을 다시 복습해보시면 이해가 되실거에요.

감사합니다.

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

0

46

2

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

0

72

1

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

0

87

1

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

0

79

1

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

0

75

1

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

0

116

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

115

2

생성자 자동주입 관련해서

0

60

1

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

0

93

2

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

1

63

1

12:25

0

74

2

appConfig.xml 오류

0

124

1