> 백엔드 개발 > PHP 튜토리얼 > php单例模式_PHP教程

php单例模式_PHP教程

WBOY
풀어 주다: 2016-07-15 13:21:27
원래의
971명이 탐색했습니다.

PHP的一个主要应用场合就是应用程序与数据库打交道的应用场景,所以一个应用中会存在大量的数据库操作,比如过数据库句柄来连接数据库这一行为,使用单例模式可以避免大量的new操作,因为每一次new操作都会消耗内存资源和系统资源。

 

【单例模式的优点】
1、对唯一实例的受控访问
2、缩小命名空间 单例模式是对全局变量的一种改进。它避免了那些存储唯一实例的全局变量污染命名空间
3、允许对操作和表示的精华 单例类可以有子类。而且用这个扩展类的实例来配置一个应用是很容易的。你可以用你所需要的类的实例在运行时刻配置应用。
4、允许可变数目的实例(多例模式)
5、比类操作更灵活

【单例模式适用场景】
1、当类只能有一个实例而且客户可以从一个众所周知的访问点访问它时
2、当这个唯一实例应该是通过子类化可扩展的。并且用户应该无需更改代码就能使用一个扩展的实例时。

【单例模式与其它模式】
工厂方法模式(factory method模式):单例模式使用工厂模式来提供自己的实例。
抽象工厂模式(abstract factory模式):抽象工厂模式可以使用单例模式,将具体工厂类设计成单例类。
建造者模式(Builder模式):建造模式可以将具体建造类设计成单例模式

 

3.单例模式实例

 3.1 test.php


 

SPAN style="FONT-SIZE: 14px"><?php 
class Test{ 
    public $service; 
     
    //静态成品变量 保存全局实例  
    private static $instance = null; 
     
    //用mysqli连接数据库  
    private static $SDB_USER = "test"; 
    private static $SDB_DBNAME="test";   
    private static $SDB_HOST = &#39;localhost&#39;; 
    private static $SDB_PASS = &#39;ddddYQ3ddddUxEY&#39;;    
     
    //私有化构造函数,防止外界实例化对象  
    private function  __construct() { 
        $this->service = new mysqli(self::$SDB_HOST, self::$SDB_USER, self::$SDB_PASS, self::$SDB_DBNAME);        
    } 
     
    //私有化克隆函数,防止外界克隆对象  
    private function  __clone(){ 
    } 
     
    //静态方法, 单例统一访问入口  
    public static function getInstance() { 
        if (!isset(self::$instance) || is_null(self::$instance)) { 
            self::$instance = new Test(); 
        } 
        return self::$instance; 
    } 
     
    //测试方法: 打印hello,world  
    public function sayHello() { 
        echo &#39;hello,world&#39;; 
    } 
} 
 
</SPAN> 

<?php
class Test{
 public $service;
 
 //静态成品变量 保存全局实例
 private static $instance = null;
 
 //用mysqli连接数据库
 private static $SDB_USER = "test";
 private static $SDB_DBNAME="test"; 
 private static $SDB_HOST = &#39;localhost&#39;;
 private static $SDB_PASS = &#39;ddddYQ3ddddUxEY&#39;; 
 
 //私有化构造函数,防止外界实例化对象
 private function  __construct() {
  $this->service = new mysqli(self::$SDB_HOST, self::$SDB_USER, self::$SDB_PASS, self::$SDB_DBNAME);  
 }
 
 //私有化克隆函数,防止外界克隆对象
 private function  __clone(){
 }
 
 //静态方法, 单例统一访问入口
 public static function getInstance() {
  if (!isset(self::$instance) || is_null(self::$instance)) {
   self::$instance = new Test();
  }
  return self::$instance;
 }
 
 //测试方法: 打印hello,world
 public function sayHello() {
  echo &#39;hello,world&#39;;
 }
}

로그인 후 복사

3.2 data.php


SPAN style="FONT-SIZE: 14px"><?php 
require_once(&#39;test.php&#39;);  
class TestObject { 
    protected $test; 
    function __construct($id=null) { 
        $this->test = Test::getInstance(); 
        $this->test->sayHello(); 
    }    
} 
 
$obj = new TestObject();</SPAN> 

<?php
require_once(&#39;test.php&#39;);
class TestObject {
 protected $test;
 function __construct($id=null) {
  $this->test = Test::getInstance();
  $this->test->sayHello();
 } 
}

로그인 후 복사

$obj = new TestObject();
运行data.php,结果:

 

 \
 

 

4.PHP单例模式实现的核心要点有如下三条:
    1.    需要一个保存类的唯一实例的静态成员变量(通常为$instance私有变量)
    2.    构造函数和克隆函数必须声明为私有的,这是为了防止外部程序new类从而失去单例模式的意义
    3.    必须提供一个访问这个实例的公共的静态方法(通常为getInstance方法),从而返回唯一实例的一个引用
5.PHP单例模式的缺点
    众所周知,PHP语言是一种解释型的脚本语言,这种运行机制使得每个PHP页面被解释执行后,所有的相关资源都会被回收。也就是说,PHP在语言级别上没有办法让某个对象常驻内存,这和asp.net、Java等编译型是不同的,比如在Java中单例会一直存在于整个应用程序的生命周期里,变量是跨页面级的,真正可以做到这个实例在应用程序生命周期中的唯一性。然而在PHP中,所有的变量无论是全局变量还是类的静态成员,都是页面级的,每次页面被执行时,都会重新建立新的对象,都会在页面执行完毕后被清空,这样似乎PHP单例模式就没有什么意义了,所以PHP单例模式我觉得只是针对单次页面级请求时出现多个应用场景并需要共享同一对象资源时是非常有意义的。

 


 

www.bkjia.comtruehttp://www.bkjia.com/PHPjc/477183.htmlTechArticlePHP的一个主要应用场合就是应用程序与数据库打交道的应用场景,所以一个应用中会存在大量的数据库操作,比如过数据库句柄来连接数据...
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿