单例模式的三种实现方式

1.饿汉模式

package com.fullstacker.study.designpattern.singleton;

/**
 * 饿汉模式 饿汉模式是线程安全的单例模式
 *
 * @author xingguishuai
 * @create 2017-03-27-15:53
 **/
public class HungrySingleton {

    private static HungrySingleton intance = new HungrySingleton();

    private HungrySingleton(){

    }

    public static HungrySingleton getIntance(){
        return intance;
    }
}

2.懒汉模式

package com.fullstacker.study.designpattern.singleton;

/**
 * 懒汉模式
 *
 * @author xingguishuai
 * @create 2017-03-27-15:58
 **/
public class LazySingleton {
    private static LazySingleton intance ;

    private LazySingleton(){

    }
    /**
    * <p>功能描述:判断是否存在存在实例,如果不存在则,创建对象
     * 此时,否则返回实例,为线程不安全</p>
    * @return
    * @param
    * @author xingguishuai
    * @Date 2017-03-27 15:59
    * @since 1.0
    */
    public static LazySingleton getIntance(){
        if(null == intance){
            intance = new LazySingleton();
        }
        return intance;
    }
    /**
     * <p>功能描述:判断是否存在存在实例,如果不存在则,创建对象
     * 此时,否则返回实例,同步方式获取,但粒度较大,效率较低,可以使用双重判断的方法以优化</p>
     * @return
     * @param
     * @author xingguishuai
     * @Date 2017-03-27 15:59
     * @since 1.0
     */
    public static synchronized LazySingleton getIntanceSyn(){
        if(null == intance){
            intance = new LazySingleton();
        }
        return intance;
    }

}

3.双重判断的方法(懒汉模式优化)

package com.fullstacker.study.designpattern.singleton;

/**
 * 双重判断法
 *
 * @author xingguishuai
 * @create 2017-03-27-16:06
 **/
public class DubbleSingleton {
    private static DubbleSingleton intance ;

    private DubbleSingleton(){

    }
    /**
     * <p>功能描述:判断是否存在存在实例,如果不存在则,创建对象
     * 此时,否则返回实例,为线程不安全</p>
     * @return
     * @param
     * @author xingguishuai
     * @Date 2017-03-27 15:59
     * @since 1.0
     */
    public static DubbleSingleton getIntance(){
        //第一次检验是否为null
        if(null == intance){
            try {
                //模拟生成对象前准备
                Thread.sleep(2000);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            //同步代码块
            synchronized (DubbleSingleton.class){
                //创建对象前,再次校验是否为null
                if(null == intance){
                    intance = new DubbleSingleton();
                }
            }
        }
        return intance;
    }

}

4.使用静态内部类来作为singleton的容器

public class StaticSingleton {

    private StaticSingleton() {}
    private static class SingletonHolder { //私有内部类在StaticSingleton 加载时,不初始化
        private static StaticSingleton instance = new StaticSingleton();
    }

    public static StaticSingleton getInstance () {
        return SingletonHolder.instance;
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值