웹애플리케이션은 여러 고객이 동시에 호출
문제상황 : 이렇게 계속적으로 호출이 일어나게 된다면 , 고객 요청이 올 때마다 똑같은 객체를 계속 새롭게 생성해야 함
1. static 영역에 객체 instance를 미리 하나 생성해서 올려둔다.
2. 이 객체 인스턴스가 필요하면 오직 getInstance() 메서드를 통해서만 조회할 수 있다.
=> 이 메서드를 호출하면 항상 같은 인스턴스를 반환한다.
3. 딱 1개의 객체 인스턴스만 존재해야 하므로,
생성자를 private으로 막아서 혹시라도 외부에서 new 키워드로 객체 인스턴스가 생성되는 것을 막는다.
SAME 은 객체 주소 비교, EQUAL은 내용
장점 : 이미 만들어진 객체를 공유해서 효율적으로 사용할 수 있다.
단점 : 싱글톤 패턴은 다음과 같은 수 많은 문제점들을 가지고 있다.
- 싱글톤 패턴 문제점
- 싱글톤 패턴을 구현하는 코드 자체가 많이 들어간다.
- 의존관계상 **클라이언트가 구체 클래스에 의존**한다. DIP를 위반한다.
- 클라이언트가 구체 클래스에 의존해서 OCP 원칙을 위반할 가능성이 높다.
- 테스트하기 어렵다
- 내부 속성을 변경하거나 초기화 하기 어렵다.
- private 생성자로 자식 클래스를 만들기 어렵다.
- 결론적으로 유연성이 떨어진다.
- 안티패턴으로 불리기도 한다.
=> 그러나 스프링 컨테이너에선 이 싱글톤 구현할 때 단점은 다 없애주고 좋은 점만 남겨둠
- 싱글톤 패턴을 위한 지저분한 코드가 들어가지 않아도 된다.
@Configuration 에 비밀이 존재
스프링이 우리가 만든 AppConfig라는 애를 상속받은 클래스로 만듦,
그래서 내가 만든 객체가 아닌 임의의 다른 클래스를 등록시켜서, 얘를 통해서 싱글톤으로 보장되게 해주는 것
@Configuration 붙이면 싱글톤 보장, 그러나 @Configuration 뻬고 @Bean으로만 하면 cglb로 변환 x => 싱글톤 보장 안해준다는 것, 이때는 new 로 찍으면 진짜 그때 그때 새로운 인스턴스를 생성하는 꼴이 되고 만다.