Java单例模式的懒汉式和饿汉式的实现

简介: 懒汉模式:

懒汉模式:

/**
 * @author baikunlong
 * @date 2020/9/12 9:20
 * 单例模式1 懒汉模式
 */
public class Single1 {
    //加上volatile关键字,解决双重检测的超小几率翻车,达到百分百单例
    private static volatile Single1 single1;
    //构造器改成私有,防止外部调用
    private Single1() {
    }
    public static Single1 getSingle1() {
        if (single1 == null) {
            synchronized (Single1.class) {
                //使用双重检查,解决了在方法体加同步锁带来的效率低下问题,这样只有当single1为空时那几个线程会进来
                if (single1 == null) {
                    System.out.println("实例对象");
                    // single1 = new Single1();这一句是非原子操作,JVM会执行三个步骤
                    //1 给single1分配内存
                    //2 调用构造器初始化成员变量,形成实例
                    //3 将single1对象指向分配的内存(这步执行完就是非null)
                    //这三个步骤顺序是不能保证的,所以可能执行了3,2还没执行,其他线程就会直接拿到single1了(但是还没初始化),就会报错了
                    //解决办法就是实例对象加上volatile关键字,volatile关键字的⼀个作⽤是禁⽌指令重排,把single1声明为volatile之后,对它的写操作就会有⼀个内存屏障(什么是内 存屏障?),这样,在它的赋值完成之前,就不⽤会调⽤读操作。
                    //注意:volatile阻⽌的不是singleton = new Singleton() 这句话内部[1-2-3]的指令重排,⽽是保证了在⼀个写操作([1-2-3])完成之前,不会调⽤读操作(if (single1 == null))。
                    single1 = new Single1();
                    System.out.println(single1);
                }
            }
        }
        return single1;
    }
    public static void main(String[] args) {
        for (int i = 0; i < 10000; i++) {
            new Thread(() -> {
                getSingle1();
            }).start();
        }
    }
}


普通版饿汉模式:

/**
 * @author baikunlong
 * @date 2020/9/12 10:14
 * 饿汉式的实现一
 */
public class Single2 {
    private static final Single2 single=new Single2();
    private Single2(){}
    public static Single2 getSingle2(){
        return single;
    }
}


加强版饿汉模式:

/**
 * @author baikunlong
 * @date 2020/9/12 10:14
 * 饿汉式的实现二
 */
public class Single3 {
    //对于内部类来说,它是饿汉式模式,在SingletonHolder初始化的时候会由ClassLoader来保证同步,使single3是⼀个真单例。
    //由于是内部类,只有当外部调用getSingle3时,才会初始化实例,则对外部来说这是一个懒汉式
    private static class SingletonHolder{
        private static final Single3 single3=new Single3();
    }
    private Single3(){}
    public static Single3 getSingle3(){
        return SingletonHolder.single3;
    }
}
目录
相关文章
|
5天前
|
设计模式 安全 Java
Java编程中的单例模式:理解与实践
【10月更文挑战第31天】在Java的世界里,单例模式是一种优雅的解决方案,它确保一个类只有一个实例,并提供一个全局访问点。本文将深入探讨单例模式的实现方式、使用场景及其优缺点,同时提供代码示例以加深理解。无论你是Java新手还是有经验的开发者,掌握单例模式都将是你技能库中的宝贵财富。
12 2
|
15天前
|
设计模式 安全 Java
Java编程中的单例模式深入剖析
【10月更文挑战第21天】在Java的世界里,单例模式是设计模式中一个常见而又强大的存在。它确保了一个类只有一个实例,并提供一个全局访问点。本文将深入探讨如何正确实现单例模式,包括常见的实现方式、优缺点分析以及最佳实践,同时也会通过实际代码示例来加深理解。无论你是Java新手还是资深开发者,这篇文章都将为你提供宝贵的见解和技巧。
92 65
|
5天前
|
设计模式 安全 Java
Java编程中的单例模式深入解析
【10月更文挑战第31天】在编程世界中,设计模式就像是建筑中的蓝图,它们定义了解决常见问题的最佳实践。本文将通过浅显易懂的语言带你深入了解Java中广泛应用的单例模式,并展示如何实现它。
|
12天前
|
设计模式 SQL 安全
Java编程中的单例模式深入解析
【10月更文挑战第24天】在软件工程中,单例模式是设计模式的一种,它确保一个类只有一个实例,并提供一个全局访问点。本文将探讨如何在Java中使用单例模式,并分析其优缺点以及适用场景。
10 0
|
16天前
|
SQL 设计模式 Java
[Java]单例模式
本文介绍了单例模式的概念及其实现方式,包括饿汉式和懒汉式两种形式,并详细探讨了懒汉式中可能出现的线程安全问题及其解决方案,如锁方法、锁代码块和双重检查锁(DCL)。文章通过示例代码帮助读者更好地理解和应用单例模式。
23 0
|
安全 Java
Java常用的单例模式
Java常用的单例模式
119 0
|
安全 Java
Java常用的单例模式
版权声明:欢迎转载,请注明沉默王二原创。 https://blog.csdn.net/qing_gee/article/details/46608497 Java的单例single经常用到,但是使用枚举enum最佳。
941 0
|
2天前
|
安全 Java 测试技术
Java并行流陷阱:为什么指定线程池可能是个坏主意
本文探讨了Java并行流的使用陷阱,尤其是指定线程池的问题。文章分析了并行流的设计思想,指出了指定线程池的弊端,并提供了使用CompletableFuture等替代方案。同时,介绍了Parallel Collector库在处理阻塞任务时的优势和特点。
|
11天前
|
安全 Java
java 中 i++ 到底是否线程安全?
本文通过实例探讨了 `i++` 在多线程环境下的线程安全性问题。首先,使用 100 个线程分别执行 10000 次 `i++` 操作,发现最终结果小于预期的 1000000,证明 `i++` 是线程不安全的。接着,介绍了两种解决方法:使用 `synchronized` 关键字加锁和使用 `AtomicInteger` 类。其中,`AtomicInteger` 通过 `CAS` 操作实现了高效的线程安全。最后,通过分析字节码和源码,解释了 `i++` 为何线程不安全以及 `AtomicInteger` 如何保证线程安全。
java 中 i++ 到底是否线程安全?
|
1天前
|
存储 安全 Java
Java多线程编程的艺术:从基础到实践####
本文深入探讨了Java多线程编程的核心概念、应用场景及其实现方式,旨在帮助开发者理解并掌握多线程编程的基本技能。文章首先概述了多线程的重要性和常见挑战,随后详细介绍了Java中创建和管理线程的两种主要方式:继承Thread类与实现Runnable接口。通过实例代码,本文展示了如何正确启动、运行及同步线程,以及如何处理线程间的通信与协作问题。最后,文章总结了多线程编程的最佳实践,为读者在实际项目中应用多线程技术提供了宝贵的参考。 ####
下一篇
无影云桌面