zoukankan      html  css  js  c++  java
  • Php面向对象 – 单例模式

    Php面向对象 – 单例模式

    保证类仅仅有一个实例

    1.    怎样能够解决一个类能够被无限地实例化?

    New,就能实例化一次,怎么去限制,用户不能无限次地new?

    将构造方法私有化。全部外部的new都操作失败

    class  MySQLDB

    {

            private  function __construct()

            {

            }

    }

    2.    一旦构造方法私有化,意味着类不能再类外实例化。但能够在类内实例化。

    添加一个公共的静态方法,通过类来调用该方法,在方法内能够运行new操作。

    class  MySQLDB

    {

            private  function __construct()

            {

            }

           

            public  static function  getInstance()

            {

                   return  new MySQLDB;

            }

    }

    $o = MySQLDB::getInstance();

    此时,用户须要该类的对象,方法内的代码就会运行,因此,我们能够通过完好方法内的逻辑,限制用户得到对象的操作。

    3.    在上面的方法内,使用这种逻辑:每次运行时做推断,推断该类是否已经实例化对象,假设实例化了,则直接返回这个实例化好的对象。假设没有实例化,则实例化一个新的,然后返回。

    怎样推断?

    在这个对象被实例化出来时,保存起来。

    样例:

    class  MySQLDB

    {

            private  static  $instance;

            private  function __construct()

            {

            }

            public  static function  getInstance()

            {

                   if(!self::$instance  instanceof self)

                   {

                          self::$instance= new self;

                   }

                   return  self::$instance;

            }

    }

    4.    克隆也能够得到新对象,因此须要限制克隆。

    私有化  __clone()方法

    class  MySQLDB

    {

            private  static  $instance;

            private  function __construct()

            {

            }

           

            private  function __clone()

            {

            }

            public  static function  getInstance()

            {

                   if(!self::$instance  instanceof self)

                   {

                          self::$instance= new self;

                   }

                   return  self::$instance;

            }

    }

  • 相关阅读:
    Educational Codeforces Round 33 (Rated for Div. 2) B. Beautiful Divisors【进制思维/打表】
    Educational Codeforces Round 33 (Rated for Div. 2) A. Chess For Three【模拟/逻辑推理】
    java中的BigInteger
    动态规划-最长上升子序列(LIS模板)多解+变形
    Rain on your Parade---hdu2389(HK求最大匹配)
    Air Raid---hdu1151(最小路径覆盖)
    Swap---hdu2819(最大匹配)
    棋盘游戏---hdu1281(最大匹配)
    The Accomodation of Students---hdu2444(二分图,最大匹配)
    COURSES---poj1469 hdu1083(最大匹配)
  • 原文地址:https://www.cnblogs.com/zfyouxi/p/4004309.html
Copyright © 2011-2022 走看看