设计模式-单例模式

单例模式:

 

单例模式有以下特点:

1、单例类只能有一个实例。

2、单例类构造器私有。

 

懒汉式单例:


public class Singleton() {

	private Singleton() {
	
	}

	private static Singleton m_instance = NULL;

	public static Singleton getInstance() {
		return this.m_instance == NULL ? new Singleton() : m_instance;
	}
}

Singleton通过将构造方法私有化避免了类在外部被实例化,等到需要实例的时候再在内部实例化。

这种方法是线程不安全的,在并发环境下可能回出现多个实例,有如下解决方法。

 

在getInstance()方法上加上同步,这种方法性能较差,因为每次都需要同步,除了第一次调用时之外,都是不需要同步的。

public class Singleton() {

	private Singleton() {
	
	}

	private static Singleton m_instance = NULL;

	public static synchronized Singleton getInstance() {
		return this.m_instance == NULL ? new Singleton() : m_instance;
	}
}

双重检查,这种方法通过判断实例是否已创建避免每次都要同步导致影响性能。

public class Singleton() {

	private Singleton() {
	
	}

	private static final Singleton m_instance = NULL;

	public static Singleton getInstance() {
		if(m_instance == NULL){
			synchronized(Singleton.class) {
				return m_instance == NULL ? new Singleton() : m_instance;
			}
		}
		return m_instance;
	}
}

静态内部类,利用了classloader的机制来保证初始化instance时只有一个线程,所以是线程安全的,同时没有性能损耗。

public class Singleton() {

	private Singleton() {
	
	}

	private static class LazyHolder() {
		private static final Singleton m_instance = new Singleton();
	}

	public static synchronized Singleton getInstance() {
		return this.LazyHolder.m_instance;
	}
}

饿汉式单例,线程安全:

public class Singleton() {

	private Singleton() {
	
	}

	private static final Singleton m_instance = new Singleton();

	public static Singleton getInstance() {
		return this.m_instance;
	}
}




  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值