单例模式懒汉试最佳写法

之所以想写这个问题,是因为之前网上很多都是这样的代码:

    private static MyApplication instance;
    public static MyApplication getInstance() {
        if (instance == null) {
            instance = new MyApplication();
        }
        return instance;
    }

这种写法线程不安全,改进一下,加一个同步锁(双重校验):

    private static MyApplication instance;
    public static MyApplication getInstance() {
         if (instance == null) {
            synchronized (MyApplication.class) {
                if (instance == null) {
                    instance = new MyApplication();
                }
            }
        }
        return instance;
    }

网上这样的代码更多,可以很好的工作,这种方式可以很好的降低同步锁的开销,但会出现 当线程A和B 执行时,B线程将看到一个还没有被初始化的对象的问题。 
这里写图片描述

实际上,早在JDK1.5就引入volatile关键字,所以又有了一种更好的双重校验锁写法:

    private volatile static MyApplication instance;
    public static MyApplication getInstance() {
        if (instance == null) {
            synchronized (MyApplication.class) {
                if (instance == null) {
                    instance = new MyApplication();
                }
            }
        }
        return instance;
    }

好处: 
1.通过双重检查锁定来降低同步的开销; 
2.保证多线程并发执行,采用 volatile 不会出现第二种方法说的那个问题.

还有一种写法:

class Foo {  
    private static class HelperHolder {
       public static final MyApplication helper = new MyApplication();
    }

    public static MyApplication getHelper() {
        return HelperHolder.helper;
    }
}

内部类能使之 延迟初始化(lazy initialization),并且多线程安全,还能保证高性能。

不是说第一、二种写法有问题,或者在Android中一定要用第三或第四种写法,只是告诉大家有更好的写法。 
以上就是我的一点小小记录,希望对你有所帮助。 
转载请标明出处: 
http://blog.csdn.net/sinat_15877283/article/details/50997664; 
本文出自: 【温利东的博客】 
参考:http://www.infoq.com/cn/articles/double-checked-locking-with-delay-initialization; 
http://www.ibm.com/developerworks/java/library/j-jtp06197/index.html; 
http://wiki.jikexueyuan.com/project/java-concurrency/synchronized-and-volatile.html; 
http://www.race604.com/java-double-checked-singleton/

单例模式懒汉线程安全的实现可以通过在getInstance方法上加锁来实现。在懒汉式的单例模式中,单例对象的初始化是延迟到第一次调用getInstance方法时才进行的。为了确保线程安全,一种常见的做法是在getInstance方法上加上synchronized关键字,使得每次只有一个线程可以进入该方法。这样可以避免多个线程同时创建实例的问题。以下是一个懒汉线程安全的单例模式示例代码: ```java public class Singleton { private static Singleton instance; private Singleton() { // 私有化构造方法,防止外部直接实例化 } public static synchronized Singleton getInstance() { if (instance == null) { instance = new Singleton(); } return instance; } } ``` 在上述示例代码中,getInstance方法被声明为synchronized,确保了线程安全,但也会导致效率较低,因为每次调用getInstance方法时都需要获取锁。因此,在实际开发中,如果不是特别需要懒加载的特性,可以考虑使用饿汉式单例模式或者双重检查锁定单例模式。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [单例模式懒汉式(线程安全)](https://blog.csdn.net/qq_44119625/article/details/123523408)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [老生常谈C++的单例模式与线程安全单例模式(懒汉/饿汉)](https://download.csdn.net/download/weixin_38741966/13783415)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值