大话设计模式-单例模式-2020-10-23

2020-10-23  本文已影响0人  松哥888

定义

保证一个类仅有一个实例,并提供一个访问它的全局访问点。

结构图

image.png

使用场景

单例多种写法的例子

  1. 懒汉模式,同步操作防止多线程创建多个对象。
/**
 * 懒汉模式的单例,线程安全
 */

class LazySingleton {
    // 私有化构造函数,防止new对象
    private LazySingleton() {}

    private static LazySingleton instance;

    // 同步方式保证线程安全,但是效率比较低下
    public static synchronized LazySingleton getInstance() {
        if (null == instance) {
            instance = new LazySingleton();
        }
        return instance;
    }
}
  1. 饿汉式单例类Eager Singleton;Android Studio的单例模板就是用这个来做的。
/**
 * 饿汉式单例类
 */
class EagerSingleton {
    //类加载时就初始化
    private static final EagerSingleton ourInstance = new EagerSingleton();

    static EagerSingleton getInstance() {
        return ourInstance;
    }

    // 防止new操作
    private EagerSingleton() {
    }
}
  1. 双重检验锁
/**
 * 双重检验锁方式的单例类
 */
class DoubleCheckSingleton {
    // 定义单例静态变量
    private volatile static DoubleCheckSingleton instance = null;

    // 构造函数私有化
    private DoubleCheckSingleton() {}

    // 获取单例对象方法
    public static DoubleCheckSingleton getInstance() {
        if (instance == null) {
            synchronized (DoubleCheckSingleton.class) {
                if (instance == null) {
                    instance = new DoubleCheckSingleton();
                }
            }
        }
        return instance;
    }
}
  1. 静态内部类方式
/**
 * 静态内部类方式单例
 */
class StaticNestedClassSingleton {
    private static class SingletonHolder {
        private static final StaticNestedClassSingleton INSTANCE = new StaticNestedClassSingleton();
    }
    private StaticNestedClassSingleton (){}
    public static final StaticNestedClassSingleton getInstance() {
        return SingletonHolder.INSTANCE;
    }
}
image.png
public class SingletonActivity extends AppCompatActivity {

    public static void launch(Context context) {
        if (null != context) {
            Intent intent = new Intent();
            intent.setClass(context, SingletonActivity.class);
            if (!(context instanceof Activity)) {
                intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
            }
            context.startActivity(intent);
        }
    }

    TextView checkTextView;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_singleton);
        setTitle("单例模式");

        checkTextView = findViewById(R.id.textViewCheck);
    }

    public void onLazyButtonClick(View view) {
        LazySingleton lazySingleton1 = LazySingleton.getInstance();
        LazySingleton lazySingleton2 = LazySingleton.getInstance();
        checkSingleton(lazySingleton1, lazySingleton2);
    }

    public void onEagerButtonClick(View view) {
        EagerSingleton eagerSingleton1 = EagerSingleton.getInstance();
        EagerSingleton eagerSingleton2 = EagerSingleton.getInstance();
        checkSingleton(eagerSingleton1, eagerSingleton2);
    }

    public void onDoubleCheckButtonClick(View view) {
        DoubleCheckSingleton doubleCheckSingleton1 = DoubleCheckSingleton.getInstance();
        DoubleCheckSingleton doubleCheckSingleton2 = DoubleCheckSingleton.getInstance();
        checkSingleton(doubleCheckSingleton1, doubleCheckSingleton2);
    }

    public void onNestedClassButtonClick(View view) {
        StaticNestedClassSingleton staticNestedClassSingleton1 = StaticNestedClassSingleton.getInstance();
        StaticNestedClassSingleton staticNestedClassSingleton2 = StaticNestedClassSingleton.getInstance();
        checkSingleton(staticNestedClassSingleton1, staticNestedClassSingleton2);
    }

    private void checkSingleton(Object object1, Object object2) {
        String message = "";
        if (object1 == object2) {
            message = "对象object1:" + object1 + "\n"
                    + "对象object2:" + object2 + "\n"
                    + "是相同的实例";
        } else {
            message = "对象object1:" + object1 + "\n"
                    + "对象object2:" + object2 + "\n"
                    + "是不同的实例";
        }
        checkTextView.setText(message);
    }
}

Demo地址

https://gitee.com/zhangxusong888/Android/tree/master/design_pattern

上一篇 下一篇

猜你喜欢

热点阅读