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

一、前言

解决单例模式中懒汉式不反对高并发,饿汉式不反对懒加载问题,的确很多小编也是写过—>
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 枚举类型自身的个性,保障了实例创立的线程安全性和实例的唯一性。比拟举荐应用

评论

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

这个站点使用 Akismet 来减少垃圾评论。了解你的评论数据如何被处理