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

베이스연주자님의 프로필 이미지

작성한 질문수

스프링 핵심 원리 - 기본편

프로토타입 스코프 - 싱글톤 빈과 함께 사용시 문제점

"싱글톤방식의 주의점"강의와 이번강의의 내용이 헷갈립니다

작성

·

194

1


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

[질문 내용]
안녕하세요 예전 강의(싱글톤방식의 주의점 ) 에서 싱글톤객체 사용시 공유되는 전역변수를 사용하면 문제가 되므로 사용하면 안된다고 이해했습니다.(싱글톤객체는 여러 쓰레드에 의해 공유되므로 )

이번 강의 에서 싱글톤객체의 필드에 프로토타입 스코프의 객체를 주입받아서 사용하는데 이 객체가 프로토타입스코프여서 문제가 되는게 아니라 해당 객체의 전역변수를 변경하는 로직이 문제가 되는거 아닌가요?

주입받는 객체가 프로토타입 스코프가 아니라 싱글톤스코프여도 여러스레드에 의해 공유되는 전역변수를 변경하는 로직이 문제가 되는건 아닌지요.

 

싱글톤사용시 공유되는 전역변수를 변경하는 로직을 사용하면 안되다고 이해했는데 이번강의 에서는 싱글톤 객체에 주입받는 객체가 프로토타입스코프여서 문제가 되는걸로 이해가 잘되질않아서요.

 

질문이 너무 두서가 없는것 같지만 해당부분이 잘이해가 안됩니다.ㅜ

 

답변 1

0

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

말씀하신 것처럼 싱글톤의 필드(전역변수)에는 상태값을 보관하여선 안됩니다.

이는 필드가 프로토타입 스코프여도 마찬가지 입니다.

 

프로토타입 스코프는 사용시마다 새로운 객체가 호출될것을 기대하지만, 싱글톤의 필드에 프로토타입 스코프 객체를 사용할 경우 마치 싱글톤처럼 동작하게 됩니다.

 

이 둘을 종합하면 싱글톤 객체의 필드에는 값을 저장하고 사용하면 안된다 입니다 🙂

감사합니다.

여전히 이해가 되지 않는 부분이 있어 추가적으로 다시 질문드립니다.

제가 궁금한건 강의의 예제에서 프로토타입스코프의 객체에 전역변수가 존재하고 해당 전역변수를 변경하는 메서드가 존재하며 그 메서드를 호출하기때문에 문제가 되는것같은데 강의에서는 프로토타입스코프인 객체라서 문제가 되는것처럼 느껴져서 헷갈렸던 겁니다.

필드에 프로토타입스코프인 객체가 아니라 싱글톤스코프인 객체를 사용했어도 예제처럼 전역변수가 존재하고 전역변수를 변경할수있는 메서드를 호출하면 문제가 될거같아서요.

프로토타입스코프인 객체를 사용해도 전역변수를 사용하지 않고 "싱글톤방식의 주의점" 강의의 예제랑 비슷하게 사용하면 문제가 안될것같은 생각이 들었습니다.

 

궁금한부분은 싱글톤스코프나 프로토타입스코프 둘중 어느걸 사용해도 공유될수 있는 전역변수와 전역변수를 변경하는 메서드는 사용하면 안될거같은데 강의에서는 프로토타입스코프를 사용할경우 싱글톤스코프와 같이 사용할때 문제가 발생하는 경우에 대해서 예제를 설명해 주셔서 헷갈리는 부분이 있어서 다시 한번 질문남깁니다..