单例模式

以后要坚持写博客了,记录下自己学习过程的点点滴滴,最近一段时间对设计模式很是感兴趣啊,也查阅了很多资料,网上大神们也有很多类似的东西,自己就当学习笔记喽。

最简单的设计模式就是单例模式。单例,顾名思义,就是只有一个实例,一个类只有一个实例,实现的方法有很多种,常见的有5种,一个一个说:

1:饿汉式单例类

public class Singleton{
	private static final Singleton singletonInstance = new Singleton();
	
	private Singleton(){
	}
	
	public static Singleton getInstance(){
		return singletonInstance;
	}
}
这种写法很明显的是可以避免多线程并发的问题,因为在类被加载时已经实例化,不存在多线程环境下得到不一致对象的问题。

2:懒汉式单例类

public class Singleton(){
	private static Singleton singletonInstance = null;
	
	private Singleton(){
	}
	
	public static Singleton getInstance(){
		if(null == singletonInstance){
			singletonInstance = new Singleton();
		}
		
		return singletonInstance;
	}
}
这种写法也非常好理解,但是很明显,它在静态方法中进行初始化,假设有两个线程同时访问getInstance方法时,有可能产生singletonInstance非单例的情况。

3:静态内部类实现

public class Singleton{
	private static class holder{
		private static final Singleton singletonInstance= new Singleton();
	}
	private Singleton(){
		
	}
	public static Singleton getInstance(){
		return holder.singletonInstance;
	}
}

因为静态内部类只有在运行时才会被加载,这样在外部类被加载时holder类并未加载,知道调用getInstance()方法时才会加载。

4:枚举实现

public enum Singleton{
	SINGLETON;
}
class TestDemo{
	public static void main(String[] args) {
		for(int i =0; i< 10; i++){
			new Thread(){
				@Override
				public void run() {
					try {
						Thread.sleep(1000);
					} catch (InterruptedException e) {
						e.printStackTrace();
					}
					Singleton sInstance = Singleton.SINGLETON;
					System.out.println(sInstance.hashCode());
				}
			}.start();
		}
	}
}
枚举不多说了吧,默认就是public static final的,果断能实现单例啊

5:双检查锁实现单例

代码不写了吧,原理就是用了synchronized代码块进行实例化,但是由于java内存模型的无序写入,这种方法依然不能实现多线程环境下的单例。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值