单例模式(懒汉模式、饿汉模式)

事实上,通过Java反射机制是能够实例化构造方法为private的类的,那基本上会使所有的Java单例实现失效。


经典的单例模式(改进型懒汉模式):if 判断语句确保对象只创建一次
public class Singleton{
    //私有化构造器
    private Singleton(){
    }

    private static Singleton instance = null;

    //synchronized用于确保线程安全

    public  synchronized static Singleton getInstance(){
        if(instance == null){
            instance = new Singleton();
        }
        return instance;
    }

}


懒汉式:

public class Singleton{
       //私有化构造器
       private Singleton(){
        }

        private static Singleton instance = null;

        public  static Singleton getInstance(){

            if(instance == null){
                instance = new Singleton();
            }
            return instance;
        }
}

饿汉式:在类初始化时就进行实例化
public class Singleton{
        private Singleton(){
        }
        private static Singleton single = new Singleton();
        public static Singleton getInstance(){
            return instance;
        }

}

异同:

相同:两种方案的实例和公用方法都是静态的(static),构造函数都是私有的(private),都通过公共(public)的方法返回实例对象。

不同:

创建的位置不同,饿汉式在类内部(方法外)创建,懒汉式在方法中创建实例(可能存在线程安全问题)

饿汉式每次调用的时候不用做创建,直接返回已经创建好的实例。这样虽然节省了时间,但是却占用了空间,实例本身为static的,会一直在内存中存在着。

③ 懒汉式则是判断,在用的时候才加载,会影响程序的速度。最关键的是,在并发的情况下,懒汉式是不安全的。如果有两个线程,我们称它们为线程1和线程2,在同一时间调用getInstance()方法,如果线程1先进入if块,然后线程2进行控制,那么就会有两个实例被创建。

class Single{
	private static Single s = null;
	private Single(){}
	public static Single getInstance(){ //锁是谁?字节码文件对象;
		if(s == null){
			synchronized(Single.class){
				if(s == null)
					s = new Single();
			}
		}
		return s;
	}
}
双重判断提高效率
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值