单例模式

原创 2015年07月08日 10:47:57

经典单利模式原理

场景:线程池、缓存、硬件设备(多个实例会造成冲突,结果不一致性)

确保一个类最多只有一个实例,并且提供一个全局访问点

经典单例

package singleton;

public class Singleton {
	private static Singleton uniqeSingleton = null;

	private Singleton() { // private 防止外面类调用产生新的对象的可能

	}

	public static Singleton getInstance() {
		if (uniqeSingleton == null) {
			uniqeSingleton = new Singleton();
		}
		return uniqeSingleton;
	}
}
</pre><p>单例模式优化</p><p></p><ul><li>多线程问题  当一个线程执行getInstance方法时,在没有执行到new Singleton时,被切换到另一个线程执行getInstance方法时,此时对象没有创建会出现多个对像</li></ul><div>解决方法:</div><div><ol><li>加同步锁即在getInstance方法加上 <span style="background-color:rgb(204,204,204)">synchronized </span>关键字,缺点同步锁比较耗资源,当该方法被频繁调用时,资源消耗大。</li><li>“急切” 创建实例,在刚开始申明uniqeSingleton时就创建了该对象的实例,即 <span style="background-color:rgb(255,255,255)">private static Singleton uniqueSingleton = </span><span style="background-color:rgb(192,192,192)">new Singleton()</span>,此时getInstance方法中的uniqeSingleton永远不为空,直接返回该对象,缺点是不管实际用没用到该对象都会创建一个实例。</li><li>双重检查加锁发,在uniqeSingleton对象前加 <span style="background-color:rgb(204,204,204)"><strong>volatile</strong></span> 关键词,在getInstance方法时,再加个锁</li></ol><div><pre name="code" class="java">package singleton;

public class Singleton {
	private volatile static Singleton uniqeSingleton = null;

	private Singleton() { // private 防止外面类调用产生新的对象的可能

	}

	public synchronized static Singleton getInstance() {
		if (uniqeSingleton == null) {
			synchronized (Singleton.class) {// 只能有一个对象进入下面创建对象,一个创建后,另一个判断的时候uniqeSingleton就不为空了
				if (uniqeSingleton == null) {
					uniqeSingleton = new Singleton();
				}
			}
		}
		return uniqeSingleton;
	}
}




版权声明:本文为博主原创文章,未经博主允许不得转载。 举报

相关文章推荐

返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)