싱글톤을 직접 만들면 안좋은 이유에 관해
229
작성한 질문수 3
몇몇 스택오버플로우 글과 이펙티브 자바를 통해, 자바에서 + 멀티쓰레드 환경에서 완벽하게 싱글톤을 구현하는 것이 거의 불가능에 가깝다고 들었습니다. 그런 이유로 스프링 컨테이너의 싱글톤을 사용한다는 말도 같이 보았는데요... 이런 말이 어느 정도 신뢰도가 있는 것인지 알고 싶습니다. (영상의 "싱글톤 컨테이너" 파트에선 이 부분을 다루지 않아 질문하게 되었습니다) . 예를 들면 이런 글입니다 : https://dzone.com/articles/enforcing-java-singletons-is-very-hard
답변 2
2
안녕하세요. 진수님 좋은 질문입니다.
제가 강의에서 설명한 싱글톤 생성 방식은 싱글톤 객체를 미리 생성해두는 방식입니다. 이렇게 static final로 미리 싱글톤 객체를 생성해두면 자바 언어가 완벽하게 하나의 싱글톤을 생성하도록 보장해줍니다.
그런데 문제가 되는 경우는 미리 싱글톤 객체를 생성해두는게 아니라, 싱글톤 객체를 처음 요청할 때 싱글톤 객체를 생성하는 방식입니다. 예를 들어서 다음처럼 코드를 작성하는 것이지요.
class HelloSingleton {
HelloSingleton instance = null;
public static getInstacne() {
if(instance ==null) {
instance = new HelloSingleton();
}
return instance;
}
}
이 경우 쓰레드2개가 최초로 동시에 getInstacne()를 호출하면 new HelloSingleton()이 2번 호출되는 문제가 발생합니다. 이 문제를 해결하기 위해 Lock을 걸거나 동시에 접근하지 못하도록 막으면 되지만, 조회 성능이 떨어질 수 있습니다. 성능도 잡으면서 동시성도 해결할 수 있는 방법이 있는데, 이게 어렵다는 것이지요. 스프링 컨테이너를 사용하면 스프링이 이런 문제도 모두 해결해주고, 완벽하게 하나의 싱글톤 객체가 생성되는 것을 보장해줍니다^^
감사합니다.
코드 자료
0
3
1
구현체가 동적으로 정해질 때, 팩토리 기법을 사용하나요?
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





