inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

스프링 핵심 원리 - 기본편

싱글톤 방식의 주의점

싱글톤 패턴 단점이 이해가 안 갑니다.

1121

khjung1654

작성한 질문수 7

1

학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭 확인해주세요.

1. 강의 내용과 관련된 질문을 남겨주세요.
2. 인프런의 질문 게시판과 자주 하는 질문(링크)을 먼저 확인해주세요.
(자주 하는 질문 링크: https://bit.ly/3fX6ygx)
3. 질문 잘하기 메뉴얼(링크)을 먼저 읽어주세요.
(질문 잘하기 메뉴얼 링크: https://bit.ly/2UfeqCG)

질문 시에는 위 내용은 삭제하고 다음 내용을 남겨주세요.
=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예/아니오)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예/아니오)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예/아니오)

[질문 내용]
스프링을 사용하시기 전에 순수 자바 코드로 싱글톤 생성하신 다음에 싱글톤 패턴이 가질 수 있는 단점에 대해 설명해주셨습니다.

  1. 싱글톤 패턴을 구현하는 코드 자체가 많이 들어간다.

  2. 의존관계상 클라이언트가 구체 클래스에 의존한다.

  3. private 생성자로 자식 클래스를 만들기 어렵다.

이 중 1번,3번은 스프링에서 개선됨이 확실하게 보이는데 2번은 크게 달라진 점을 모르겠습니다.

자바로만 싱글톤 만들었을 때 활용
(SingletonService가 MemberService를 상속받았다고 가정했을 때)

public class AppConfig {

    public MemberService memberService(){
        return SingletonService.getInstance();
    }
}
public class SingletonTest {

    @Test
    @DisplayName("스프링 없는 순수한 DI 컨테이너")
    void pureContainer() {
        AppConfig appConfig = new AppConfig();
        MemberService memberService1 = appConfig.memberService();
        // 활용
    }
}

이렇게 만들면 의존관계상 클라이언트가 구체 클래스에 의존하지 않는 것 아닌가요?

물론 다른 단점들이 다 고쳐지니 스프링을 안 쓸 이유가 없지만 DIP, OCP 개선을 중요하게 언급하신 것 같아서 넘어가기 찝찝하네요. 자바로 만들 때 DIP가 위반되는 이유가 뭔가요?

oop spring

답변 1

0

David

안녕하세요. khjung1654님, 공식 서포터즈 David입니다.

2번의 경우, AppConfig 와 같이 설정 정보 클래스를 사용하지 않는 것을 전제합니다.

설정 정보 클래스를 사용하지 않고 클라이언트 코드에서 XXXSingleton.getInstance() 와 같은 코드를 사용하게 되므로, 추상이 아닌 구체에 의존하게 되어 DIP를 위반하게 됩니다.

다만, 말씀하신대로 설정 정보 클래스를 만들고, 추상에 의존하도록 설계한다면 2번 항목은 해당되지 않습니다.

감사합니다.

섹션3. 11 회원객체 다이어그램

0

22

1

OCP, DIP과 @Qualifier 어노테이션에 대해서 질문합니다.

0

24

1

코드 자료

0

54

2

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

0

62

2

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

0

83

1

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

0

94

1

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

0

81

1

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

0

81

1

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

0

125

2

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

0

89

1

provider 사용하는 이유

0

93

1

다음 강의 뭘 들어야 할까요

0

130

2

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

0

66

1

beanB

0

82

2

퀴즈다시풀기

0

69

1

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

0

92

2

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

0

67

3

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

0

106

2

도메인의 정의?

0

59

1

ApplicationContext 질문입니다.

0

63

1

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

0

93

2

ai api 선정하기 관련 질문

0

122

2

생성자 자동주입 관련해서

0

67

1

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

0

97

2