ANDROID-JAVA-单例模式优化&多线程并发

最近线上遇到了很多莫名其妙的问题,最后发现是因为子线程和主线程同时去初始化单例造成的
我本来的单例是这么写的。像大家这种有脑子的肯定明白问题出在哪里。但是我没有。然后花费了好久的时间才证实,原来多线程会造成多份数据。

    private DeviceManager() {
            LogManager.get().getLogger(this.getClass()).info("获取门店基础数据出现异常"!看这里));
    }

    public static DeviceManager get() {
        if (instance == null) {
            instance = new DeviceManager();
        }
        return instance;
    }

调用代码:
ANDROID-JAVA-单例模式优化&多线程并发_第1张图片
日志记录:
在这里插入图片描述

我在子线程和主线程上同时去打印了数据,证明了数据不一致:
在这里插入图片描述
然后我就去看了下单例的多线程并发:
原文入口: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

你可能感兴趣的:(android)