inflearn logo
강의

Course

Instructor

Spring Core Principles - Basic Edition

Singleton Pattern

getInstance() 메소드에도 static이 필요한가요?

1193

lsj59285

35 asked

0

instance를 new로 선언하는 첫 줄의 코드에는 당연히 static이 필요합니다.
private static final SingletonService instance = new SingtonService();

 

그런데 다음 코드인 getInstance() 메소드까지 static이 필요한 이유를 잘 모르겠어서 여쭤봅니다.
public static SingletonService getInstance() {
return instance;
}

spring oop

Answer 3

7

codetrain999

안녕하세요, lsj59285 님! 공식 서포터즈 codesweaver 입니다.

우선 멤버변수 instance 가 private 접근 제어자 이기에 외부에서 이 멤버변수에 직접 접근할 수 없습니다. (static 임에도 불구하고!)

멤버변수 instance에 접근할 수 있는 방법이 필요한데 그게 getInstance() 메서드 입니다. (이 메서드는 public 접근 제어자를 갖습니다)

 

이제 getInstance() 메서드 에서 멤버변수 instance 에 접근해야 하는데 이때 또 문제가 있습니다.

바로 'static 영역에서 힙 영역을 참조할 수 없다' 는 자바 문법 사항 때문입니다.

static 은 프로그램에서 유일한 영역이고, 인스턴스는 힙 영역에 N개로 늘어날 수 있습니다.

그래서 static 과 힙 영역의 인스턴스는 1:N 관계가 됩니다.

그래서 힙 영역의 인스턴스가 static 영역을 참조할 수 있으나, static영역에서 힙 영역의 인스턴스를 참조할 순 없습니다.

N개의 인스턴스가 존재할 수 있기에, 어떤 인스턴스를 지칭하는지 알 방법이 (자바 문법 상으론) 없습니다.

 

이 문제를 해결하려면 getInstance() 메서드 또한 static 영역에 있어야 합니다. (물론 외부에서 접근하려면 이 메서드는 public 접근제어자를 가져야 합니다!)

감사합니다.

4

lsj59285

아... 멤버변수 instance가 static이라서 getInstance() 메소드가 static인 게 아니라,

getInstance() 메소드가 static이라서 멤버변수 instance도 static이여야 되는 거군요?

위 말이 맞다면 제가 순서를 반대로 생각하고 질문을 한 거네요.

0

hjhjhj3770217732

글을 읽다 궁금한점이 생겨 질문 드립니다.

getInstance()가 static 메서드라서 instance 도 static 영역에 두었다고 하셨는데 instance는 공유할 수 있도록 static 영역으로 먼저 보냈 게 아닌가요??...

getInstance()를 static영역으로 보낸건 생성자가 private니까 객체생성이 안되서 인스턴스 메서드를 사용을 못하니까 그런거 아닌가요??ㅠ

답변주시면 정말 감사하겠습니다.

0

codetrain999

안녕하세요 박희재님.

static 영역에 존재하는 데이터는, 앱 전체가 공유할 수 있는것이 맞으나, 문제는 접근제어자가 private 이라는 점 입니다. 그래서 외부에서 이를 직접 접근할 수 없습니다. 그래서 public 메서드를 이용하여 접근해야 하는데 그게 바로 getInstance() 메서드죠. 이 메서드가 static 이어야 하는 이유는 희재님이 말씀해주신 이유도 맞습니다. 생성자가 private 접근제어자를 갖기에 인스턴스를 생성할 수 없기 때문이기도 합니다.

 

감사합니다.

 

 

0

hjhjhj3770217732

답변감사합니다.

제가 지금 헷갈리는 게 위에 질문분 처럼 getInstance() 메소드가 static이라서 멤버변수 instance도 static이여야한다 라고 생각하는 과정이 맞는건지 궁금합니다.

클래스메소드가 인스턴스변수를 사용할 수 없는건 맞지만 instance먼저 static 영역으로 보내지고 getInstance() 메소드는 instance가 private기 때문에 이것에 접근하기 위해 public 메소드가 되고 생성자도 private이기 때문에 객체를 생성할 수 없어 static 메소드가 되야한다고 이해했습니다.

답변해주시면 감사하겠습니다.

0

codetrain999

안녕하세요 박희재님.

생각하신 내용이 맞습니다 :)

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

0

46

2

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

0

72

1

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

0

87

1

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

0

79

1

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

0

75

1

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

0

116

2

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

0

81

1

provider 사용하는 이유

0

83

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

115

2

생성자 자동주입 관련해서

0

60

1

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

0

92

2

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

1

63

1

12:25

0

74

2

appConfig.xml 오류

0

124

1