单例设计模式:确保一个类只有一个实例,并提供全局访问点。
代码1:
缺点:还是需要同步有一定的性能损耗。
代码2:
这种方式优点:实现了懒加载并且没有性能消耗。主要是由于第一次加载该类的时候jvm并没没有加载内部类只有当调用getinstance的时候才会加载。所以是懒加载。内部类是在外部类有了引用之后才加载。
代码3:枚举。
代码1:
public class Singleton {
//volatile修饰防止jvm指令重排引起错误
private volatile static Singleton singleton;;
private Singleton(){
}
public Singleton getInstance(){
if(singleton==null){
synchronized (Singleton.class) { //只有第一次会初始化会进入,提升效率
if(singleton==null){//再检查一遍
singleton= new Singleton();
}
}
}
return singleton;
}
}
缺点:还是需要同步有一定的性能损耗。
代码2:
public class SingletonInner {
private SingletonInner(){
}
public SingletonInner getInstance(){
return Inner.singletonInner;
}
static class Inner{
private static SingletonInner singletonInner = new SingletonInner();
}
}
这种方式优点:实现了懒加载并且没有性能消耗。主要是由于第一次加载该类的时候jvm并没没有加载内部类只有当调用getinstance的时候才会加载。所以是懒加载。内部类是在外部类有了引用之后才加载。
代码3:枚举。