【单例模式】饿汉式,懒汉式?JAVA如何实现单例?线程安全吗?

简介: 【单例模式】饿汉式,懒汉式?JAVA如何实现单例?线程安全吗?


Java单例设计模式

  • 单例设计模式(Singleton):单例即唯一实例,某个类在整个系统中只能有一个实例对象可被获取和使用的代码模式。(例如:代表JVM运行环境的Runtime类)


要点

  • ①某个类只能有一个实例。
  • 构造器私有化。
  • ②这个类必须自行创建这个实例。
  • 含有一个该类的静态变量来保存这个唯一的实例。
  • ③这个类必须自行向整个系统提供这个实例。
  • 对外提供获取该实例的方式:
  1. 直接暴露
  2. 用静态变量的get方法获取


饿汉式

  • 饿汉式:直接创建对象,不存在线程安全问题。(在类初始化时直接创建对象,不管你是否需要这个对象都会创建)
  • 实现方式:
  • 直接实例化饿汉式(简洁明了)
  • 枚举式(最简洁)
  • 静态代码块饿汉式(适合复杂实例化)


  1. 直接实例化
//Singleton:单例设计模式,软件开发中常见的设计模式之一
//单例设计模式——饿汉式1:直接实例化饿汉式
/*
 * 1.构造器私有化
 * 2.自行创建,并且用静态变量保存
 * 3.向外提供这个实例
 * 4.使用final修饰,强调这是一个单例
 */
public class Singleton_hungry1 {
  //直接实例化
  private static final Singleton_hungry1 INSTANCE = new Singleton_hungry1();
  //构造器私有化
  private Singleton_hungry1(){}
}


  1. 枚举式
/**
 * 枚举类型:表示该类型的变量是有限的几个
 * 我们可以限定为一个,从而成了单例
 *
 */
public enum Singleton_hungry2 {
  //枚举类型的实例
  INSTANCE;
  private Singleton_hungry2() {}
}


  1. 静态代码块
public class Singleton_hungry3 {
  public static final Singleton_hungry3 INSTANCE;
  static {
    //复杂情况在静态代码块中解决
    INSTANCE = new Singleton_hungry3();
  }
  private Singleton_hungry3() {}
}


懒汉式

  • 懒汉式:延迟创建对象。
  • 实现方式:
  • 线程不安全(适用于单线程)
  • 线程安全(适用于多线程)
  • 静态内部类形式(适用于多线程)
  1. 线程不安全
/*
 * 懒汉式:延迟创建这个实例对象
 * 1. 构造器私有化
 * 2.用一个静态变量保存唯一实例
 * 3.提供一个静态方法,用于获取实例*/
public class Singleton4 {
  private static Singleton4 instance;
  private Singleton4() {}
  //线程不安全
  public static Singleton4 getInstance() {
    if(instance == null) {
      instance = new Singleton4();
    }
    return instance;
  }
}


  1. 线程安全
public class Singleton5 {
  private static Singleton5 instance;
  private Singleton5() {}
  public static Singleton5 getInstance() {
    //上锁、线程安全
    synchronized(Singleton5.class){
      if(instance == null) {
        instance = new Singleton5();
      }
    }
    return instance;
  }
}


  1. 静态内部类形式
/*
 * 懒汉式:延迟创建这个实例对象
 * 1. 构造器私有化
 * 2.用一个静态变量保存唯一实例
 * 3.提供一个静态方法,用于获取实例*/
public class Singleton6 {
  private Singleton6() {}
  //内部类:静态内部类不会随着外部类的加载和初始化而初始化,它是要单独去加载和初始化的
  //唯一实例因为是在内部类加载和初始化时才创建的,所以线程安全
  private static class inner{
    //唯一实例: 在内部类被加载和初始化时才被创建
    private static Singleton6 instance = new Singleton6();
  }
  public static Singleton6 getInstance() {
    return inner.instance;
  }
}




目录
相关文章
|
4天前
|
Java 调度
Java线程的六种状态
Java线程有六种状态: 初始(NEW)、运行(RUNNABLE)、阻塞(BLOCKED)、等待(WAITING)、超时等待(TIMED_WAITING)、终止(TERMINATED)。
13 1
|
1天前
|
安全 Java 开发者
Java并发编程中的线程安全性与性能优化
在Java编程中,处理并发问题是至关重要的。本文探讨了Java中线程安全性的概念及其在性能优化中的重要性。通过深入分析多线程环境下的共享资源访问问题,结合常见的并发控制手段和性能优化技巧,帮助开发者更好地理解和应对Java程序中的并发挑战。 【7月更文挑战第14天】
|
1天前
|
监控 Java API
Java并发编程之线程池深度解析
【7月更文挑战第14天】在Java并发编程领域,线程池是提升性能、管理资源的关键工具。本文将深入探讨线程池的核心概念、内部工作原理以及如何有效使用线程池来处理并发任务,旨在为读者提供一套完整的线程池使用和优化策略。
|
4天前
|
缓存 安全 Java
Java中线程池如何管理?
【7月更文挑战第11天】Java中线程池如何管理?
9 2
|
4天前
|
安全 算法 Java
Java中线程安全怎么做?
【7月更文挑战第11天】Java中线程安全怎么做?
10 2
|
4天前
|
存储 安全 算法
深入理解Java并发编程:线程安全与性能优化
【5月更文挑战第72天】 在现代软件开发中,尤其是Java应用开发领域,并发编程是一个无法回避的重要话题。随着多核处理器的普及,合理利用并发机制对于提高软件性能、响应速度和资源利用率具有重要意义。本文旨在探讨Java并发编程的核心概念、线程安全的策略以及性能优化技巧,帮助开发者构建高效且可靠的并发应用。通过实例分析和理论阐述,我们将揭示在高并发环境下如何平衡线程安全与系统性能之间的关系,并提出一系列最佳实践方法。
|
3天前
|
Java 调度
java中线程的6种状态
java中线程的6种状态
|
3天前
|
算法 Java 开发者
Java中的多线程编程技巧与实践
在现代软件开发中,多线程编程成为提升应用程序性能和响应能力的关键技术之一。本文将深入探讨Java语言中多线程编程的基础概念、常见问题及其解决方案,帮助开发者更好地理解和应用多线程技术。 【7月更文挑战第12天】
6 0
|
2月前
|
安全 Java
java保证线程安全关于锁处理的理解
了解Java中确保线程安全的锁机制:1)全局synchronized方法实现单例模式;2)对Vector/Collections.SynchronizedList/CopyOnWriteArrayList的部分操作加锁;3)ConcurrentHashMap的锁分段技术;4)使用读写锁;5)无锁或低冲突策略,如Disruptor队列。
28 2
|
2月前
|
存储 安全 Java
深入理解Java并发编程:线程安全与锁机制
【5月更文挑战第31天】在Java并发编程中,线程安全和锁机制是两个核心概念。本文将深入探讨这两个概念,包括它们的定义、实现方式以及在实际开发中的应用。通过对线程安全和锁机制的深入理解,可以帮助我们更好地解决并发编程中的问题,提高程序的性能和稳定性。