单例模式

2017-07-04  本文已影响59人  i冰点
1、饿汉模式

声明静态对象的时候初始化

public class SingleInstance {
    private static SingleInstance INSTANCE=new SingleInstance();
    private SingleInstance() {}
    public static SingleInstance getInstance(){
        return INSTANCE;
    }
}

但是,因为类在第一次使用的时候会被加载到内存(如果此时没有调用 getInstance() ),因为 instance 是静态变量,也会导致单例对象被创建。

2、懒汉模式

当类第一次获取单例对象的时候初始化

public class SingleInstance {
    private static SingleInstance INSTANCE;
    private SingleInstance() {}
    public static SingleInstance getInstance(){
        if (INSTANCE==null){
            INSTANCE=new SingleInstance();
        }
        return INSTANCE;
    }
}

当然,在单线程的环境下,是没有问题的,但是如果,多线程并发访问,就会创建多个SingleInstance对象,这个时候,可以使用synchronized进行线程同步。

    private static SingleInstance INSTANCE;
    private SingleInstance() {}
    public static synchronized SingleInstance getInstance(){
        if (INSTANCE==null){
            INSTANCE=new SingleInstance();
        }
        return INSTANCE;
    }

但是,即便INSTANCE已经存在了,每次调用 getInstance()方法,都会进行同步,会降低程序的效率,可以使用同步代码块,同步关键代码

public class SingleInstance {
    private static SingleInstance INSTANCE;
    private SingleInstance() {}
    public static SingleInstance getInstance(){
        if (INSTANCE==null){
            synchronized (SingleInstance.class){
                if(INSTANCE==null){
                    INSTANCE=new SingleInstance();
                }
            }
        }
        return INSTANCE;
    }
}
3、静态内部类

关于内部类
把一个类放到另一个类的内部定义,就是内部类。

记住下面几个规则:

创建对象

因为内部类,直到使用的时候才加载,即第一次调用SingleInstanceHolder.INSTANCE时,SingleInstance才会创建

public class SingleInstance {
    private SingleInstance() {}
    public static SingleInstance getInstance(){
        return SingleInstanceHolder.INSTANCE;
    }
    private static class SingleInstanceHolder{
         static SingleInstance INSTANCE=new SingleInstance();
    }
}

2、kotlin下的单利模式

上一篇 下一篇

猜你喜欢

热点阅读