懒汉式单利模式多线程终极解决方案

首先要说的是,饿汉式的单利是能保证多线程安全的,开发都是这么玩的,除非你要单利的对象有特殊情况,比如创建这个对象很消耗系统资源,个人感觉大部分的懒汉式的单利模式却被当成了面试题问的比较多。


比如 连珠炮

先回问你,单利模式知道吗?什么是懒汉式,什么是饿汉式?有笔吧?来!把代码写出来

等你搞定以后,

又问你,你看你写的懒汉式的单利模式有没有什么问题?

你可能低头看了一眼代码,然后回答:哦,多线程不安全。

然后面试官又问:那怎么让它是线程安全的呢?

你说:方法上使用synchronized或者使用同步代码块加锁。

面试官面无表情点点头,那加上锁以后就OK了吗?有什么问题吗?

你又犹豫了几秒说道:不论是在方法上加锁还是方法内使用同步代码块,都会影响性能。

面试官:那怎么解决啊?

你:终极解决方案就是:双检查锁机制。在来一张纸!!。

package test;

public class MySingle {
	private static MySingle single =null;
	private MySingle() {

	}
	//既能保证创建了对象的,不会过锁浪费资源
	//又能保证多线程安全(过了MySingle.class 对象锁,也过不了if判断)
	public static MySingle getSingle() throws InterruptedException {
		if(single==null){
			Thread.sleep(2000);//及时线程在这多睡几秒也没事
			synchronized(MySingle.class){
				if(single==null){
					single=new MySingle();
				}
			}
		}
		return single;
	}

}

懒汉式单利模式多线程终极解决方案_第1张图片


你可能感兴趣的:(多线程,创建型设计模式)