Dev/Design Patterns
[Design pattern] Singleton - 싱글톤 디자인 패턴
surimi🍥
2021. 11. 18. 23:56
반응형
Singleton Pattern
프로세스 실행 중에 오직 하나의 객체만 생성되도록 강제하는 디자인 패턴.
싱글톤이 적용된 클래스의 객체를 여러개 생성해도 모두 하나의 객체만을 가리키게 된다.
결국, 해당 객체는 단 하나만 만들어지게 되는 것.
# 싱글톤 클래스 정의
싱글톤 클래스는 static 변수(instance)가 존재한다.
싱글톤 클래스에서 내부 static 변수가 정의되어 있지 않다면,
static 변수에 현재 객체(this)를 할당해주고, 이 변수를 return해준다.
class Singleton{
static instance;
if(!Singleton.instance){
Singleton.instance = this;
}
return Singleton.instance;
}
이제 클라이언트 코드에서 여러 싱글톤 객체를 만들어 주고 비교해보면,
두 객체는 동일한 것을 확인할 수 있다.
let s1 = new Singleton();
let s2 = new Singleton();
if(s1 === s2){
console.log("same"); // 출력됨.
}else{
console.log("diff");
}
프로세스가 실생되면,
프로세스의 실행부터 종료까지 유지되는 정적(static) 인스턴스가 생성되며, 이 인스턴스는 undefined, 즉 아무것도 가리키지 않는다.
클라이언트 동작에 따라 s1 객체가 선언되며 생성자(constructor)가 호출되면 static 인스턴스는 Singleton 객체를 가리키게 된다.
다음으로 s2 객체가 선언될 때는, static 인스턴스가 이미 값을 가지고 있으므로 바로 그 값을 반환한다. 여기서 값이란 s1때 생성된 Singleton 객체이다.
결론적으로, s1과 s2는 같은 객체를 가리키기 때문에 둘은 싱글톤이다(같다)라고 표현할 수 있다.
이후로 아무리 Singleton 객체를 생성해도, 모두 같은 객체를 가리키게 된다.
예제
class SingleCat {
static instance;
constructor(name) {
this.name = name;
if (!SingleCat.instance) {
SingleCat.instance = this;
}
return SingleCat.instance;
}
speak() {
console.log(this.name, 'meow!');
}
}
let cat1 = new SingleCat('Nabi');
let cat2 = new SingleCat('Kitty');
if (cat1 === cat2)
console.log("same cat!"); // 출력됨.
else
console.log("different cat!");
cat1.speak(); // Nabi meow!
cat2.speak(); // Nabi meow!
# 싱글톤 패턴이 사용되는 경우
- 하나의 객체가 많은 리소스를 차지할 때.
- 객체가 외부 네트워크와 연결되는데 이 네트워크가 동시에 단 하나만 연결되어야 할 때.
# 참조 링크
Youtube link
Factory Design pattern
반응형