最近线上遇到了很多莫名其妙的问题,最后发现是因为子线程和主线程同时去初始化单例造成的
我本来的单例是这么写的。像大家这种有脑子的肯定明白问题出在哪里。但是我没有。然后花费了好久的时间才证实,原来多线程会造成多份数据。
private DeviceManager() {
LogManager.get().getLogger(this.getClass()).info("获取门店基础数据出现异常"!看这里));
}
public static DeviceManager get() {
if (instance == null) {
instance = new DeviceManager();
}
return instance;
}
调用代码:
日志记录:
我在子线程和主线程上同时去打印了数据,证明了数据不一致:
然后我就去看了下单例的多线程并发:
原文入口:ANDROID-JAVA-单例模式优化&多线程并发
这位博主总结得可好,然后现在我改成了这样
private static final Object objectLock = new Object(); // 定义同步锁
private DeviceManager() {
LogManager.get().getLogger(this.getClass()).info("获取门店基础数据出现异常"!看这里));
}
public static DeviceManager get() {
if (instance == null) {
synchronized (objectLock) {
if (null == instance) {
instance = new DeviceManager();
}
}
}
return instance;
}
GAMEOVER