inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

스프링 핵심 원리 - 기본편

5. 싱글톤 컨테이너 - 싱글톤 패턴의 단점 부분 질문입니다.

해결된 질문

340

송진우

작성한 질문수 13

0

안녕하세요,

  1. 싱글톤 컨테이너 - 싱글톤 패턴의 단점 부분에서 질문이 있습니다.

     

스프링 컨테이너가 빈을 싱글톤으로 관리하는 부분에 대해 설명하시는 강의이므로 ["컨테이너에 의한 싱글톤"과 비교하여 "일반 싱글톤 패턴"이 갖는 단점]이라는 측면으로 이해하려 합니다.

 

감사합니다.

spring 객체지향 싱글톤

답변 2

0

김영한

안녕하세요. 백엔드해야지님

싱글톤을 직접 사용할 경우, 보통은 DI를 하지 않고 구체 클래스를 바로 의존하도록 사용합니다.

왜냐하면 이런 의도로 public static의 getInstance() 메서드를 제공하는 것이지요.

따라서 구체클래스.getInstance()를 호출하는 방식을 주로 사용합니다.

궁금해하시는 문제들은 모두 여기서 파생되는 문제입니다 :)

감사합니다.

0

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴입니다.

백엔드해야지님의 질문에 대해 답변드리겠습니다.

  • 일반적인 싱글톤 패턴의 경우, 클라이언트 코드가 싱글톤 인스턴스를 가져오기 위해 싱글톤 클래스의 getInstance 메서드를 직접 호출해야 합니다. 이것은 클라이언트 코드가 구체 클래스에 직접 의존하게 만들어 DIP(의존 역전 원칙)를 위반하고, 결과적으로 OCP(개방-폐쇄 원칙) 또한 위반할 가능성을 높입니다. 즉, 이 단점은 싱글톤 패턴이 갖는 고유의 문제입니다. 스프링 컨테이너 같은 IoC 컨테이너를 사용한다면 이러한 문제를 추상화를 통해 해결할 수 있습니다.

  • 싱글톤 객체는 전역적으로 하나의 인스턴스만을 유지하므로 상태를 변경하거나 초기화하기 어려운 문제가 있습니다. 본래 구현된 싱글톤 패턴은 코드 내에서 싱글톤 인스턴스의 상태를 변경하려 할 때, 프로그램 전반에 걸쳐 영향을 미칠 수 있는 부분을 신중하게 관리해야 하며, 특히 테스트 환경에서는 독립적인 테스트가 어렵습니다. 스프링 컨테이너를 사용하면, 설정 변경을 통해 객체의 속성을 쉽게 변경할 수 있습니다.

  • 마지막으로, 싱글톤 패턴은 자체적으로 DI를 구현하기 어렵습니다. 인스턴스화 로직이 싱글톤 클래스 안에 고정되어 있기 때문에 다른 구현체로 교체하기가 번거롭거나 때로는 불가능할 수 있습니다. 이러한 구조는 코드의 유연성을 떨어뜨리며, 컨테이너를 사용하지 않는 경우라도 마찬가지로 이러한 단점을 갖게 됩니다. 그러나 스프링 컨테이너를 이용하면, IoC를 통해 객체를 관리함으로써 이러한 단점을 보완할 수 있습니다.

감사합니다.

코드 자료

0

50

2

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

0

56

2

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

0

78

1

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

0

92

1

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

0

81

1

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

0

77

1

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

0

122

2

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

0

87

1

provider 사용하는 이유

0

90

1

다음 강의 뭘 들어야 할까요

0

126

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

90

2

ai api 선정하기 관련 질문

0

118

2

생성자 자동주입 관련해서

0

66

1

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

0

97

2

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

1

66

1

12:25

0

79

2