Back-End/Spring

[Spring][스프링 기본편] - 15. 싱글톤 패턴 적용과 테스트 그리고 수많은 문제점들

얄루몬 2022. 1. 26. 10:02

 

1. 싱글톤 패턴이란?

  • 클래스의 인스턴스가 딱 1개만 생성되는 것을 보장하는 디자인 패턴이다.
  • 그래서 객체 인스턴스를 2개 이상 생성하지 못하도록 막아야 한다.
    • private 생성자를 사용해서 외부에서 임의로 new 키워드를 사용하지 못하도록 막아야 한다.

 

 

 

 

2.싱글톤 패턴의 생성

package hello.core.singleton;

public class SingletonService {

    //static 영역공부 해야 됨
    private static final SingletonService instance = new SingletonService();

    public static SingletonService getInstance(){
        return instance;
    }


    //private를 이용해 다른 곳에서의 접근을 막아둠
    private SingletonService(){

    }
    public void logic(){
        System.out.println("싱글톤 객체 로직 호출");
    }
}
  • 1. static 영역에 객체 instance를 미리 하나 생성한다.
  • 2. 이 객체인스턴스가 필요하면 오직 getInstance() 메서드를 통해서만 조회할 수 있게 한다. 이때 이 메서드를 호출하게 될 때 항상 같은 인스턴스를 반환해준다.
  • 3. 딱 1개의 객체 인스턴스만 존재해야 하기때문에, 생성자를 private로 막아 외부에서 new 키워드로 객체 인스턴스 생성되는 것을 막아준다.

 

 

 

3. 싱글톤 테스트

 

<외부 접근으로 인한 private>

외부에서 싱글톤에 접근하게 될 때 에러 발생

error: SingletonService() has private access in SingletonService SingletonService singletonService = new SingletonService(); ^

 

 

<외부에서 싱글톤을 접근하는 방법>

 

 

 

4. 싱글톤 테스트의 문제점

싱글톤 테스트는 클래스 당 1개의 객체만을 생성해 누군가가 이를 다시 생성하려 할 때 생성한 것을 이용하게 해주어 메모리 절감을 가능하게 한다. 하지만 이외에 너무 많은 단점들이 있어서 싱글톤의 단점을 알아보고 스프링은 이를 어떻게 해결하는가를 살펴보자.

 

싱글톤 패턴 문제점

  • 싱글톤 패턴을 구현하는 코드 자체가 많이 들어간다.
  • 의존관계상 클라이언트가 구체 클래스에 의존한다.
  • DIP를 위반한다.
  • 클라이언트가 구체 클래스에 의존해서 OCP 원칙을 위반할 가능성이 높다.
  • 테스트하기 어렵다.
  • 내부 속성을 변경하거나 초기화 하기 어렵다.
  • private 생성자로 자식 클래스를 만들기 어렵다.
  • 결론적으로 유연성이 떨어진다.
  • 안티패턴으로 불리기도 한다.
    • 안티패턴이라고 불리는 이유는 장점보다 수많은 단점을 가지고 있기 때문이다.

 

다음 포스팅에서 계속 싱글톤의 단점을 상쇄시키는 스프링의 특징을 살펴보도록 하겠다.

 

 

 

5.출처

https://inf.run/7GX1

 

스프링 핵심 원리 - 기본편 - 인프런 | 강의

스프링 입문자가 예제를 만들어가면서 스프링의 핵심 원리를 이해하고, 스프링 기본기를 확실히 다질 수 있습니다., - 강의 소개 | 인프런...

www.inflearn.com