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