加入收藏 | 设为首页 | 会员中心 | 我要投稿 温州站长网 (https://www.0577zz.com/)- 低代码、办公协同、物联平台、操作系统、5G!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

PHP设计设计模式-单例模式实践笔记

发布时间:2023-11-11 11:01:59 所属栏目:PHP教程 来源:转载
导读:   概要



  创建型模式



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



  特点



  1、一个类只有一个实例



  2、它必须自行创建这个实
  概要
 
  创建型模式
 
  保证一个类仅有一个实例,并且提供一个访问它的全局访问点
 
  特点
 
  1、一个类只有一个实例
 
  2、它必须自行创建这个实例
 
  3、必须自行向整个系统提供这个实例
 
  结构图
 
  Singleton
 
  主要角色
 
  Singleton 定义一个Instance操作,允许客户访问它的唯一实例。Instance是一个类方法。负责创建它的唯一的实例。
 
  优缺点
 
  1、对唯一实例的受控访问
 
  2、缩小命名空间 单例模式是对全局变量的一种改进。它避免了那些存储唯一实例的全局变量污染命名空间
 
  3、允许对操作和表示的精华 单例类可以有子类。而且用这个扩展类的实例来配置一个应用是很容易的。你可以用你所需要的类的实例在运行时刻配置应用。
 
  4、允许可变数目的实例(多例模式)
 
  5、比类操作更灵活
 
  适用性
 
  1、当类只能有一个实例而且客户可以从一个众所周知的访问点访问它时
 
  2、当这个唯一实例应该是通过子类化可扩展的。并且用户应该无需更改代码就能使用一个扩展的实例时。
 
  单例模式php实例
 
   代码如下
 
  1
 
           /**
 
           * 单例模式
 
           * ————-
 
           * @author         zhaoxuejie
 
           * @package     design pattern
 
           * @version     v1.0 2011-12-14
 
           */
 
          class Singleton {
 
              //私有静态成员变量,保存全局实例
 
              private static $instance = NULL; 
              
              //私有构造方法,保证外界无法直接实例化
 
              private function __construct(){}

              //静态方法,返回此类唯一实例
 
              public static function getInstance(){
 
                  if(!isset(self::$instance)){
 
                      $c = __CLASS__;
 
                      self::$instance = new $c;
 
                  }
 
                  return self::$instance;
 
              }              
 
              //测试用方法
 
              public function info(){
 
                  return ‘ok’;
 
              }
 
              //防止克隆
 
              public function __clone(){
 
                  throw new Exception(‘Error: Clone is not allowed.’);
 
              }
 
          }
 
          $s = Singleton::getInstance();
 
          echo $s->info();
 
   ?>
 
  补充我看到另一篇关于单例模式介绍
 
   代码如下
 
  1
 
  class EasyFramework_Easy_Mysql{
 
      protected static $_instance = null;
 
      private function __construct(){
 
  2     }
 
      public static function getInstance(){
 
          if (self::$_instance === null){
 
              self::$_instance = new self();
 
          }
 
          return self::$_instance;
 
      }
 
  3     protected function __clone(){
 
  4     }
 
  5 }
 
  $x = EasyFramework_Easy_Mysql::getInstance();
 
  var_dump($x);
 
  6 ?>
 
  7 /*
 
   * 1.第一步:
 
   * 既然是单例,也就是只能实例化一次,也就代表在实例化时
 
   * 不可能使用new关键字!!!!
 
   * 在使用new关键字时,类中的构造函数将自动调用。
 
   * 但是,如果我们将构造函数的访问控制符设置为protected或private
 
   * 那么就不可能直接使用new关键字了!!!
 
   * 第二步:
 
   * 无论protected/private修饰的属性或方法,请问在当前类的
 
   * 内部是否可以访问?---> 可以
 
   * 第三步:
 
   * 现在我们根本没有办法得到对象(因为你不能使用new关键字了),
 
   * 第四步:静态成员(包括属性或方法)在访问时,只能通过
 
   * 类名称::属性()
 
   * 类名称::方法()
 
   * 第五步:如果我现在存在一个静态方法--> getInstance()
 
   * 那么在调用时就应写成
 
   * $object = EasyFramework_Easy_Mysql::getInstance()
 
   * 如果,getInstance()方法可以得到唯一的一个对象
 
   * 也就代表是所谓的单例模式了!!!
 
   * 第六步,怎么让getInstace()只得到一个对象呢?
 
   * 既然要得到对象,那么肯定是:
 
   * $variabl = new ????();
 
   * 我们又知道静态属性的值是可以所有的对象来继承的!!!
 
   * 静态成员是属于类的,而非对象的!
 
   * 所以:
 
   * 第七步:声明一个静态的属性,用其存储实例化的对象
 
   * protectd static $_instance
 
   *
 
   * 并且初始值为null
 
   * 那么我在调用getInstance()方法时,只需要判断其值是否为空即可
 
   *
 
   * public static function getInstance(){
 
   *     if(self::_instance === null){
 
   *      self::_instance = new self();
 
   *  }
 
   *  return self::_instance;
 
   * }
 
   * 在实例时,一定是这样写:
 
   * $x = EasyFramework_Easy_Mysql::getInstance();
 
   * 在第一时调用时,类的$_instance这个静态属性值为null,
 
   * 那么也就代表,getInstance()方法的判断条件为真了,
 
   * 也就意味着
 
   * self::$_instance这个成员有了值了!!!
 
   * 并且还返回这个值
 
   * $y = EasyFramework_Easy_Mysql::getInstance();
 
   * 在第二次或第N次调用时,self::$_instance已经有了值了
 
   * 也就代表getInstance()方法的条件为假了!!!
 
   * 也就代表其中的程序代表不可能执行了!!!
 
   * 也就代表将直接返回以前的值了!!!
 
   *
 
   *
 
   *
 
   * */
 

(编辑:温州站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章