• Android与设计模式——单例(Singleton)模式


    概念:
      java中单例模式是一种常见的设计模式。单例模式分三种:懒汉式单例、饿汉式单例、登记式单例三种。
      单例模式有一下特点:
      1、单例类仅仅能有一个实例。


      2、单例类必须自己自己创建自己的唯一实例。
      3、单例类必须给全部其它对象提供这一实例。

      单例模式确保某个类仅仅有一个实例。并且自行实例化并向整个系统提供这个实例。在计算机系统中,线程池、缓存、日志对象、对话框、打印机、显卡的驱动程序对象常被设计成单例。这些应用都或多或少具有资源管理器的功能。每台计算机能够有若干个打印机,但仅仅能有一个Printer Spooler,以避免两个打印作业同一时候输出到打印机中。每台计算机能够有若干通信port,系统应当集中管理这些通信port,以避免一个通信port同一时候被两个请求同一时候调用。

    总之,选择单例模式就是为了避免不一致状态,避免政出多头。(此段来源与网络)

    单例模式在Android源码中使用的非常广泛,在我熟悉的Telephony模块就用到了不少,比方说SIM卡的管理UiccController,电话管理CallManager等。以下看看单例模式的基本模型:


    懒汉式单例:

    public final class CallManager {
         .......
        // Singleton instance
        private static final CallManager INSTANCE = new CallManager();
          .......
        /**
         * get singleton instance of CallManager
         * @return CallManager
         */
        public static CallManager getInstance() {
            return INSTANCE;
        }
        .......
        private CallManager() {
        .......
        }
        .......
    }

    此例使用时直接用CallManager.getInstance()调用就可以获得CallManager实例。


    饿汉式单例:

    public class UiccController extends Handler {
        ......
        private static UiccController[] mInstance = {null, null, null, null};
        ......
        public static UiccController make(Context c, CommandsInterface ci, int simId) {
            synchronized (mLock) {
                if (FeatureOption.MTK_GEMINI_SUPPORT) {
                    if(mInstance[simId] != null) {
                        throw new RuntimeException("UiccController.make() should only be called once");
                    }
                    mInstance[simId] = new UiccController(c, ci, simId);
                    return mInstance[simId];
                } else {
                    if (mInstance[0] != null) {
                        throw new RuntimeException("UiccController.make() should only be called once");
                    }
                    mInstance[0] = new UiccController(c, ci);
                    return mInstance[0];
                }
            }
        }
        ......
        public static UiccController getInstance(int simId) {
            synchronized (mLock) {
                if (FeatureOption.MTK_GEMINI_SUPPORT) {
                    if(mInstance[simId] == null) {
                        throw new RuntimeException(
                            "UiccController.getInstance can't be called before make()");
                    }
                    return mInstance[simId];
                } else {
                    if (mInstance[0] == null) {
                        throw new RuntimeException(
                            "UiccController.getInstance can't be called before make()");
                    }
                    return mInstance[0];
                }
            }
        }
        ......
        private UiccController(Context c, CommandsInterface ci, int simId) {
        ......
        }
        ......
    
    }


    此例使用时,先UiccController.make()创建实例。然后UiccController.getInstance()获取实例。


    登记式单例:

    临时没找到样例。。。


    未完待续,有不正确的地方,请指正。

  • 相关阅读:
    具有快表的地址变换机构
    npm更换淘宝镜像
    内存扩充技术
    内存管理的概念
    内存的基础知识
    102. 二叉树的层序遍历
    104. 二叉树的最大深度
    206. 反转链表
    mysql 多字段查询,全局搜素
    java 处理html转义字符
  • 原文地址:https://www.cnblogs.com/mfmdaoyou/p/6910599.html
Copyright © 2020-2023  润新知