인프런 커뮤니티 질문&답변

nurugji님의 프로필 이미지
nurugji

작성한 질문수

스프링 핵심 원리 - 기본편

싱글톤 방식의 주의점

무상태

작성

·

450

1

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

[질문 내용]
싱글톤을 사용할 때는 상태를 유지하지 않는 무상태로 설계해야 하는데, 무상태라는 말을 어떻게 이해해야 할까요?

하나의 객체를 공유하면서 각자 변경은 할 수 있어야 하는데..

답변 2

0

안녕하세요. nurugji님, 공식 서포터즈 코즈위버입니다.

효권님의 답변중 '인스턴스 변수'를 '멤버 변수'로 이해하시면 될 것 같습니다 :)

감사합니다.

0

안녕하세요! 제가 감히 질문에 답변을 하자면 쉽게 말해서 "무상태" 라는 말은 인스턴스 변수를 가지지 않는 것을 의미합니다.

싱글톤을 사용할때는 왜 무상태로 설계를 해야하는가?
싱글톤이라는 것이 사용자 요청대로 객체를 생성하는 것이 아닌, 객체를 단 하나만 생성해서 사용하는 패턴입니다. 싱글톤 객체에 인스턴스 변수가 존재하면, 여러 스레드에서 하나의 인스턴스 변수에 접근할 수 있게됩니다. 그렇게 되면 A 스레드에서 인스턴스 변수1의 값을 사용해서 비즈니스 로직을 수행하는 동안, B 스레드에서 인스턴스 변수1의 값을 변경하면 A 스레드에서 수행중이던 비즈니스 로직에 이상이 생길 수 있겠죠?
이러한 이슈말고도 다른 이유가 있겠지만, 싱글톤을 사용할 때는 무상태로 설계해야합니다.

 

무상태로 설계하기 하기위해서는, 인스턴스 변수를 사용하지 않고 스레드 로컬, 파라미터를 통한 전달 등 다양한 방법이 있습니다.

 

감사합니다!

 

nurugji님의 프로필 이미지
nurugji

작성한 질문수

질문하기