먼저 싱글턴 패턴의 정의를 살펴보겠습니다.
싱글턴 패턴은 Java에서 가장 간단한 디자인 패턴 중 하나이며 객체를 생성하는 가장 좋은 방법을 제공합니다. 싱글톤 패턴에는 단일 객체만 생성되도록 하면서 자체 객체 생성을 담당하는 단일 클래스가 포함됩니다.
(권장 튜토리얼: Java Getting Started Tutorial)
메모리에 객체가 하나만 있는지 확인하고 메모리를 소비하는 객체가 자주 생성되지 않도록 하려면 이 객체를 호출해야 할 때마다 이 싱글톤을 사용하세요. .
다음으로 싱글턴 패턴의 유형을 살펴보겠습니다.
1. 레이지 스타일
레이지 스타일은 필요할 때만 싱글턴 객체가 생성된다는 의미입니다.
게으른 스타일의 싱글톤 패턴 구현:
public class Singleton { private static Singleton singleton; private Singleton(){ } public static Singleton getInstance(){ if (singleton == null) { singleton = new Singleton(); } return singleton; }
게으른 스타일의 싱글톤 구현에 문제가 있습니다. 즉, 객체가 하나만 생성되도록 하는 방법이 있을까요? 두 개 이상의 스레드가 동시에 싱글톤이 비어 있다고 판단하면 여러 개체가 생성됩니다. 따라서 스레드 안전성 문제를 해결해야 합니다.
스레드 안전성에 관해 생각나는 것은 잠금입니다. 잠금은 메서드나 클래스 개체에 대한 잠금에 지나지 않습니다.
//在方法上加锁 public class Singleton { private static Singleton singleton; private Singleton(){} public static synchronized Singleton getInstance() { if (singleton == null) { singleton = new Singleton(); } return singleton; } } //在类对象上加锁 public class Singleton { private static Singleton singleton; private Singleton(){} public static Singleton getInstance() { synchronized(Singleton.class) { if (singleton == null) { singleton = new Singleton(); } } return singleton; } }
이 두 가지 방법은 싱글톤 개체를 생성하는 멀티 스레드 문제를 동시에 해결할 수 있지만 개체를 얻을 때마다 먼저 잠금을 획득해야 하며 동시성 성능이 좋지 않습니다. 따라서 여전히 최적화가 필요합니다. 최적화 목표는 인스턴스화된 객체가 없으면 잠그고 생성하는 것입니다. 인스턴스화된 객체가 있으면 직접 반환합니다.
(학습 영상 추천 : java 강좌)
메서드에 대한 잠금은 인스턴스화된 객체 유무에 관계없이 잠금이 필요합니다. 따라서 우리가 최적화해야 할 것은 클래스 객체를 잠그는 것입니다.
//DCL单例模式(Double Check + Lock) public class Singleton { //volatite关键词防止指令重排序,下文介绍 private static volatile Singleton singleton; private Singleton(){} public static Singleton getInstance() { //如果singleton不为空,则直接返回对象,若多个线程发现singleton为空,则进入分支 if (singleton == null) { //多个线程同时争抢一个锁,只有一个线程能成功,其他线程需等待 synchronized(Singleton.class) { //争抢到锁的线程需再次判断singleton是否为空,因为有可能被上个线程实例化了 //若不为空则实例化,后续线程再进入的时候则直接返回该对象 //对于之后所有进入该方法的线程则无需获取锁,直接返回对象 if (singleton == null) { singleton = new Singleton(); } } } return singleton; } }
명령 재정렬을 방지하기 위해 위 코드에 휘발성 키워드가 추가되었습니다.
2. Hungry Chinese 스타일
Hungry 중국 스타일은 클래스가 로드될 때 싱글톤 객체가 생성된다는 의미입니다.
Hungry 중국식 싱글턴 패턴 구현:
public class Singleton { private static final Singleton singleton = new Singleton(); private Singleton(){ } public static Singleton getInstance(){ return singleton; }
요약:
Lazy Man 스타일: 개발 시 메모리 요구 사항이 높을 경우 다중 스레드 환경에서는 Lazy Man 스타일을 사용합니다. DCL 싱글턴 모드를 사용해야 하며, DCL 싱글턴 모드를 사용하면 동시성 보안 및 낮은 성능 문제를 해결합니다. 휘발성 키워드를 추가하면 명령 재정렬로 인해 발생하는 NPE 예외도 방지할 수 있습니다.
Hungry Chinese 스타일: 클래스가 로드될 때 개체가 이미 인스턴스화되었습니다. 메모리 요구 사항이 높지 않으면 간단하고 오류가 발생하지 않으며 동시성 보안 및 성능이 없습니다. 문제.
위 내용은 싱글턴 패턴에 대한 자세한 소개의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!