码迷,mamicode.com
首页 > 其他好文 > 详细

单例模式

时间:2017-04-14 22:36:15      阅读:218      评论:0      收藏:0      [点我收藏+]

标签:null   目的   多线程   多个   nbsp   延迟加载   同步   函数   类锁   

单例模式下饿汉模式效率最好
 
饿汉模式
class Single
{
     private static final Single s=new Single();
    private Single(){}
    public static Single getInstance()
    {
        return s;
    }
}
 
 
懒汉式  延迟加载实例的单列模式
class Single
{
    private static  Single s=null;
    private Single(){}//构造函数是私有的,只能在本类中实例化该类。
    public static Single getInstance()//类外面通过调用该类的静态方法实例化该类
    {//这种模式目的是只能实例化类的一个对象,不能实例化多个对象。
//但是当多线程对其调用时,可能会在进入f(s==null) 后线程释放CPU,另一个线程进入仍然对  f(s==null)的判断为真,那么会导致再次实例化对象,使得S指向另个一个空间,因为这里类的实例化对象是属于类的, static  Single s引发更改错误。     
可以getInstance()加上同步,但是这样会找出效率低效,因为多线程调用时每次都要判断锁。      
            if(s==null)
                s=new Single();  
           return s;
      }
}
 
 
强化懒汉式
class Single
{
    private static  Single s=null;
    private Single(){}
    public static Single getInstance()
    {      
        if(s==null)
        {             
                synchronized(Single.class)//这里方法是静态方法,不能使用对象this锁,只能使用类锁
                {
                    if(s==null)
                        s=new Single();  
                }
            }
           return s;
      }

}

单例模式

标签:null   目的   多线程   多个   nbsp   延迟加载   同步   函数   类锁   

原文地址:http://www.cnblogs.com/chenshizhutou/p/6710965.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!