java线程安全的单例模式

public class SingleInstance {

	//此处使用vlatile关键字修饰 instance,确保instance对于每个线程都可见,
	//即每个线程都能拿到最新的instance的值。
	private volatile static SingleInstance instance;
	
	private SingleInstance(){}
	
	public static SingleInstance getInstance(){
		
		
		if(null == instance){
			
			//使用全局类锁,保证同步
			synchronized (SingleInstance.class) {
				
				//避免重复创建对象提高效率
				if(null == instance){
					instance = new SingleInstance();
				}
			}
		}
		
		return instance;
	}
	
}



JVM编译的过程中会出现指令重排的优化过程,这就会导致当 instance实际上还没初始化,就可能被分配了内存空间,也就是说会出现 instance !=null 但是又没初始化的情况,这样就会导致返回的 instance 不完整


第二种使用内部类


public class SingletonInner {

	/** 
     * 内部类实现单例模式 
     * 延迟加载,减少内存开销 
     *  
     *  类级内部类相当于其外部类的static成员,它的对象与外部类对象间不存在依赖关系,
     *  相互独立,因此可直接创建。而对象级内部类的实例,是必须绑定在外部对象实例上的。
     *  类级内部类只有在第一次被使用的时候才被会装载
     *  
     * @author xuzhaohu 
     *  
     */  
    private static class SingletonHolder {  
        private static SingletonInner instance = new SingletonInner();  
    }  
  
    /** 
     * 私有的构造函数 
     */  
    private SingletonInner() {  
  
    }  
  
    public static SingletonInner getInstance() {  
        return SingletonHolder.instance;  
    }  
  
    protected void method() {  
        System.out.println("SingletonInner");  
    }  
	
	
}







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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值