• 博客园logo
  • 会员
  • 众包
  • 新闻
  • 博问
  • 闪存
  • 赞助商
  • HarmonyOS
  • Chat2DB
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录
山高我为峰
博客园    首页    新随笔    联系   管理    订阅  订阅
单例模式
//1.单例模式的通用代码
public class Singleton{
    private static final Singleton singleton=new Singleton();
    private Singleton(){}
    
    public static Singleton getSingleton(){
        return singleton;
    }
    //类中的其他方法
}

//2.线程不安全的单例模式
public class Singleton{
    private static final Singleton singleton=null;
    private Singleton(){}
    //通过该方法获取实例对象
    public static Singleton getSingleton(){
        if(singleton==null){
            singleton=new Singleton();
        }
        return singleton;
    }
    //类中的其他方法
}

第二钟单例模式当系统压力增大,并发量增加时则可能在内存中出项多个实例,破坏了最初的预期。出现这种情况是因为如果一个线程A执行到
singleton=new Singleton(),但是还没有获得对象(对象初始化是需要使时间的),第二个线程B也在执行,执行到(single==null)
判断,那么线程B获得判断的条件为真,于是继续运行下去,在内存中就会出现两个对象。

其次,在考虑到对象的复制情况下。在Java中,对象默认是不可以被复制的,若实现了Cloneable接口,并实现了clone方法,则可以直接通过
对象复制方式创建一个新的对象,对象复制是不用调用类的构造函数,因此即使是私有的构造函数,对象仍然可以被复制。在一般情况下,类
复制的情况不需要考虑,很少会出现一个单例类会主动要求被被复制的情况,解决该问题的最好方法就是单例类不要实现Cloneable接口。

posted on 2016-05-04 16:43  山高我为峰  阅读(183)  评论(0)    收藏  举报
刷新页面返回顶部
博客园  ©  2004-2025
浙公网安备 33010602011771号 浙ICP备2021040463号-3