关于java:解决单例模式中懒汉式不支持高并发饿汉式不支持懒加载问题最简单方法基于枚举类型的单例实现

32次阅读

共计 845 个字符,预计需要花费 3 分钟才能阅读完成。

一、前言

解决单例模式中懒汉式不反对高并发,饿汉式不反对懒加载问题,的确很多小编也是写过 —>
DCL(Double Check Lock 双重检锁机制)解决单例模式中懒汉式不反对高并发,饿汉式不反对懒加载问题

动态外部类解决单例模式中懒汉式不反对高并发,饿汉式不反对懒加载问题
大家都能够看一下。

二、代码实现

– 单例模式对象

import java.util.concurrent.atomic.AtomicInteger;

public class Single {private AtomicInteger count = new AtomicInteger(3);

    public int getReduce(){return count.decrementAndGet();
    }

}

– 枚举类型对象

public enum PhoneEnum {
    PHONE_ENUM;

    private Single instance;
    PhoneEnum() {instance = new Single();
    }
    public Single getInstance() {return instance;}
    
}

– 测试类

public class BingFa {public static void main(String[] args) {

        // 创立 3 个线程,线程外面进行加操作
        for (int i = 0; i < 3; i++) {new Thread(() -> {Single instance = PhoneEnum.PHONE_ENUM.getInstance();
                int reduce = instance.getReduce();
                System.out.println(Thread.currentThread().getName()+
                                    "线程抢到了手机,残余手机数量"+"-----"+reduce);
            }, String.valueOf(i)).start();}
    }
}

– 测试后果

三、总结

最简略的实现形式,基于枚举类型的单例实现。这种实现形式通过 Java 枚举类型自身的个性,保障了实例创立的线程安全性和实例的唯一性。比拟举荐应用

正文完
 0