Java中常用的单列模式也就是两种,单列模式其实就是保证只能出现一个对象,就像任务管理器那样,通常情况下如果创建某个对象特别耗费资源,那么这个时候可以使用单列模式,单列模式包括懒汉式和饿汉式,其中,懒汉式是需要的时候才会new一个对象,而饿汉式是不管需要不需要都会new一个对象,也叫做延时加载与非延时加载。饿汉式的效率高,懒汉式更能节省资源。
懒汉式代码
public class Dome01 {
//懒汉式加载
private static Dome01 instance;
private Dome01(){};
public synchronized static Dome01 getInstance(){
if(instance ==null){
instance=new Dome01();
}
return instance;
}
}
其中如果引用多线程,那么在new一个对象的时候可能会造成指令的重排,即一个线程可能拿到一个空的对象,为了避免这种情况,我们可以在私有属性类前加上volatile。同时为了增加程序执行的效率,我们可以在get方法里面再加入判断,即如果instance不为空,那么直接返回。这样可以增加程序的效率。同时将锁的范围减小,只是锁Dome01对象。
饿汉式代码
public class Demo02 {
//饿汉式加载
private static Demo02 instance=new Demo02();
private Demo02(){};
public static Demo02 getInstance(){
return instance;
}
}
饿汉式由于在创建的时候有天然的线程的安全,因此不用担心线程安全的问题,但是由于是直接创建了对象,不管后面会不会用到对象,因此会造成资源的浪费,但是效率大大的提高。
双重锁实现
在实际应用中双重锁可能会出现问题,使用并不推荐使用双重锁
静态内部类
即在类里面再定义一个类,在内部类里面去new一个对象,然后再使用方法返回这个类里面的对象,这种方法既可以缓加载而且效率还高。
public class Demo03 {
private static class Getdemo03{
private static final Demo03 instance=new Demo03();
}
public static Demo03 getinstance(){
return Getdemo03.instance;
}
private Demo03(){};
枚举类型
public enum Demo04 {
INSTANCE;
public static void uu(){
}
}
得助于枚举类型天然的优势,使得枚举类型也是效率高节省资源,但是缺点就是不能够缓加载