单例模式--解决多线程并发问题

1、final的作用:防止子类不适当的重写父类中的方法,破坏单例模式
2、私有的构造方法,只能类内第哦啊用,但是私有不能防止反射来创建新的实例
3、防止多线程并发访问问题:懒汉和饿汉有所不同

饿汉式:

静态变量的初始化,时在类加载过程(类加载只有异常)中完成,不会有多线程并发问题
在这里插入图片描述

package com.example.dtest.design23.singleton.hunger;

public class Mgr01 {

//    静态变量的初始化,时在类加载过程(类加载只有异常)中完成,不会有多线程并发问题
    private static  final Mgr01 INSTANCE = new Mgr01();
//      私有的构造方法
    private Mgr01(){};

    public static  Mgr01 getInstance(){
        return INSTANCE;
    }

    public void m(){
        System.out.println("m");
    }

}

懒汉式:双重检测

在这里插入图片描述

package com.example.dtest.design23.singleton.lazy;

/**
 * lazy loading
 * 也称懒汉式
 * 虽然达到了按需初始化的目的,但却带来线程不安全的问题
 * 可以通过synchronized解决,但也带来效率下降
 */
public class Mgr06 {

    private static volatile Mgr06 INSTANCE;//JIT

    private Mgr06(){
    }

    public static Mgr06 getInstance(){
//            双重检测:这里第一次判断INSTANCE是否时null
//            首次访问会同步,之后的不会再进入,但可能同时有多个已经进入第一个判断中在排队等锁
        if(INSTANCE == null){
            synchronized (Mgr06.class){
                
//            双重检测:这里第二次判断INSTANCE是否时null
                if(INSTANCE == null){
                    INSTANCE = new Mgr06();
                }
            }
        }
        return INSTANCE;
    }

    public void m(){
        System.out.println("m");
    }

}

测试:

package com.example.dtest.design23.singleton.lazy;

public class LazyTest {

    public static void main(String[] args) {

        for(int i=0;i<100;i++){

            new Thread(()->{
                System.out.println(Mgr06.getInstance().hashCode());
            }).start();

        }

    }

}

在这里插入图片描述

3、枚举类

枚举类:https://blog.csdn.net/qq_43470725/article/details/121338890

package com.example.dtest.design23.singleton.lazy.lazyEnum;

//枚举类构建的单例不能被反序列化和反射模式破坏
//INSTANCE在类加载阶段完成
//枚举类的实例只有一个INSTANCE
public enum  Mgr08 {

    INSTANCE;

//    public void m(){
//    }

    public static void main(String[] args) {
        for(int i=0;i<100;i++){
            new Thread(()->{
                System.out.println(Mgr08.INSTANCE.hashCode());
            }).start();
        }
    }

}

测试:
在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值