单例模式

经典单利模式原理

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

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

经典单例

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;
	}
}




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值