android中通常会用到单例模式的场景.
含义:确保某类有且只有一个对象.
单例模式的写法有几种,常见的有”懒汉式“和"饿汉式",但是这两种方式有一定的隐患,下面介绍另外两种方式,仅供参考:
第一种:
public class Singleton {
private static Singleton sInstance;
// 构造函数私有化
private Singleton() {
}
// 提供一个全局的静态方法
public static Singleton getInstance() {
if (sInstance == null) {
synchronized (Singleton.class) {
if (sInstance == null) { //(1)
sInstance = new Singleton();
}
}
}
return foo;
}
}
这种写法既解决了”懒汉式“的多线程问题,又解决了"饿汉式"的资源浪费的现象.
标识(1) 对sInstance判断null的原因: sInstance = new Singleton()看起来是一行代码,但实际上它并不是一个原子操作,这句代码最终会编译成多条汇编指令,它大致做了3件事情:
1.给Singleton的实例分配内存
2.调用 Singleton()的构造函数,初始化成员字段
3.将sInstance对象指向分配的内存空间(此时sInstance就不是null了)
第二种:
第一种方式虽然在一定程度上解决了资源消耗,多余的同步,线程安全的问题,但是它还是在某些情况下出现失效的问题,这个问题被称为双重检查锁定(DCL)失效,所以在并发编程中指出
这种"优化"是丑陋的,不赞成使用,建议使用如下代码替代.
public class Singleton {
private Singleton() {}
public static Singleton getInstance() {
return SingletonHolder.sInstance
}
//静态内部类
public static class SingletonHolder {
private static final Singleton sInstance = new Singleton();
}
}
此种方式的好处:当第一次加载Singleton类是并不会初始化sInstance,只有在第一次调用Singleton的getInstance()方法时才会导致sInstance被初始化.因此第一次调用getInstance()方法会
导致虚拟机加载SingletonHolder类,这种方式不仅能够保证线程安全,也能够保证单例对象的唯一性,同时也延迟了单例对象的实例化,推荐使用这种单例模式实现方法.
android单例模式的使用
最新推荐文章于 2022-11-05 21:20:49 发布