栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > PHP

php单例模式

PHP 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

php单例模式

一、什么是单例模式?

1、含义   

   作为对象的创建模式,单例模式确保某一个类只有一个实例,而且自行实例化并向整个系统全局地提供这个实例。它不会创建实例副本,而是会向单例类内部存储的实例返回一个引用。

2、单例模式的三个要点:

(1). 需要一个保存类的唯一实例的静态成员变量:

[php] view plaincopyprint?

  1. private static $_instance;   


(2). 构造函数和克隆函数必须声明为私有的,防止外部程序new类从而失去单例模式的意义:


[php] view plaincopyprint?

  1. private function __construct()   

  2. {   

  3.     $this->_db = pg_connect('xxxx');  

  4. }   

  5. private function __clone()  

  6. {  

  7. }//覆盖__clone()方法,禁止克隆  

  8.    


(3). 必须提供一个访问这个实例的公共的静态方法(通常为getInstance方法),从而返回唯一实例的一个引用 

[php] view plaincopyprint?

  1. public static function getInstance()    

  2. {    

  3.     if(! (self::$_instance instanceof self) )   

  4.     {    

  5.         self::$_instance = new self();    

  6.     }  

  7.     return self::$_instance;    

  8.   

  9. }   




二、为什么要使用单例模式?

1、PHP缺点:        

        PHP语言是一种解释型的脚本语言,这种运行机制使得每个PHP页面被解释执行后,所有的相关资源都会被回收。也就是说,PHP在语言级别上没有办法让某个对象常驻内存,这和asp.net、Java等编译型是不同的,比如在Java中单例会一直存在于整个应用程序的生命周期里,变量是跨页面级的,真正可以做到这个实例在应用程序生命周期中的唯一性。然而在PHP中,所有的变量无论是全局变量还是类的静态成员,都是页面级的,每次页面被执行时,都会重新建立新的对象,都会在页面执行完毕后被清空,这样似乎PHP单例模式就没有什么意义了,所以PHP单例模式我觉得只是针对单次页面级请求时出现多个应用场景并需要共享同一对象资源时是非常有意义的。


2、单例模式在PHP中的应用场合:

(1)、应用程序与数据库交互

        一个应用中会存在大量的数据库操作,比如过数据库句柄来连接数据库这一行为,使用单例模式可以避免大量的new操作,因为每一次new操作都会消耗内存资源和系统资源。

(2)、控制配置信息

        如果系统中需要有一个类来全局控制某些配置信息, 那么使用单例模式可以很方便的实现.


三、如何实现单例模式?

1、普通的数据库访问例子:

[php] view plaincopyprint?

  1. ......  

  2. //初始化一个数据库句柄  

  3. $db = new DB(...);  

  4.   

  5. //添加用户信息  

  6. $db->addUserInfo(...);  

  7.   

  8. ......  

  9.   

  10. //在函数中访问数据库,查找用户信息  

  11. function getUserInfo()  

  12. {  

  13.     $db = new DB(...);//再次new 数据库类,和数据库建立连接  

  14.     $db = query(....);//根据查询语句访问数据库  

  15. }  

  16.   

  17. ?>  


2、应用单例模式对数据库进行操作:

[php] view plaincopyprint?

  1.   

  2. class DB    

  3. {    

  4.     private $_db;    

  5.     private static $_instance;    

  6.     

  7.     private function __construct(...)    

  8.     {    

  9.         $this->_db = pg_connect(...);//postgrsql    

  10.     }    

  11.     

  12.     private function __clone() {};  //覆盖__clone()方法,禁止克隆    

  13.     

  14.     public static function getInstance()    

  15.     {    

  16.         if(! (self::$_instance instanceof self) ) {    

  17.             self::$_instance = new self();    

  18.         }    

  19.         return self::$_instance;    

  20.     }    

  21.     

  22.       

  23.   

  24.     public function addUserInfo(...)  

  25.     {  

  26.   

  27.      

  28.   

  29.     }  

  30.   

  31.      public function getUserInfo(...)  

  32.     {   

  33.   

  34.     }  

  35.   

  36. }  

  37.   

  38. //test  

  39.   

  40. $db = DB::getInstance();  

  41.   

  42. $db->addUserInfo(...);  

  43.   

  44. $db->getUserInfo(...);  

  45.   

  46.   

  47. ?>  





3、深入理解


[php] view plaincopyprint?

  1. class db {  

  2.     public $conn;  

  3.     public static $sql;  

  4.     public static $instance=null;  

  5.     private function __construct(){  

  6.         require_once('db.config.php');  

  7.         $this->conn = mysql_connect($db['host'],$db['user'],$db['password']);  

  8.         if(!mysql_select_db($db['database'],$this->conn)){  

  9.             echo "失败";  

  10.         };  

  11.         mysql_query('set names utf8',$this->conn);         

  12.     }  

  13.     public static function getInstance(){  

  14.         if(is_null(self::$instance)){  

  15.             self::$instance = new db;  

  16.         }  

  17.         return self::$instance;  

  18.     }  

  19.       

  20.     public function select($table,$condition=array(),$field = array()){  

  21.         $where='';  

  22.         if(!empty($condition)){  

  23.               

  24.             foreach($condition as $k=>$v){  

  25.                 $where.=$k."='".$v."' and ";  

  26.             }  

  27.             $where='where '.$where .'1=1';  

  28.         }  

  29.         $fieldstr = '';  

  30.         if(!empty($field)){  

  31.               

  32.             foreach($field as $k=>$v){  

  33.                 $fieldstr.= $v.',';  

  34.             }  

  35.              $fieldstr = rtrim($fieldstr,',');  

  36.         }else{  

  37.             $fieldstr = '*';  

  38.         }  

  39.         self::$sql = "select {$fieldstr} from {$table} {$where}";  

  40.         $result=mysql_query(self::$sql,$this->conn);  

  41.         $resuleRow = array();  

  42.         $i = 0;  

  43.         while($row=mysql_fetch_assoc($result)){  

  44.             foreach($row as $k=>$v){  

  45.                 $resuleRow[$i][$k] = $v;  

  46.             }  

  47.             $i++;  

  48.         }  

  49.         return $resuleRow;  

  50.     }  

  51.       

  52.      public function insert($table,$data){  

  53.         $values = '';  

  54.         $datas = '';  

  55.         foreach($data as $k=>$v){  

  56.             $values.=$k.',';  

  57.             $datas.="'$v'".',';  

  58.         }  

  59.         $values = rtrim($values,',');  

  60.         $datas   = rtrim($datas,',');  

  61.         self::$sql = "INSERT INTO  {$table} ({$values}) VALUES ({$datas})";  

  62.         if(mysql_query(self::$sql)){  

  63.             return mysql_insert_id();  

  64.         }else{  

  65.             return false;  

  66.         };  

  67.      }  

  68.        

  69.     public function update($table,$data,$condition=array()){  

  70.         $where='';  

  71.         if(!empty($condition)){  

  72.               

  73.             foreach($condition as $k=>$v){  

  74.                 $where.=$k."='".$v."' and ";  

  75.             }  

  76.             $where='where '.$where .'1=1';  

  77.         }  

  78.         $updatastr = '';  

  79.         if(!empty($data)){  

  80.             foreach($data as $k=>$v){  

  81.                 $updatastr.= $k."='".$v."',";  

  82.             }  

  83.             $updatastr = 'set '.rtrim($updatastr,',');  

  84.         }  

  85.         self::$sql = "update {$table} {$updatastr} {$where}";  

  86.         return mysql_query(self::$sql);  

  87.     }  

  88.       

  89.      public function delete($table,$condition){  

  90.         $where='';  

  91.         if(!empty($condition)){  

  92.               

  93.             foreach($condition as $k=>$v){  

  94.                 $where.=$k."='".$v."' and ";  

  95.             }  

  96.             $where='where '.$where .'1=1';  

  97.         }  

  98.         self::$sql = "delete from {$table} {$where}";  

  99.         return mysql_query(self::$sql);  

  100.           

  101.      }  

  102.       

  103.     public static function getLastSql(){  

  104.         echo self::$sql;  

  105.     }  

  106.       

  107.       

  108.       

  109. }  

  110.   

  111. $db = db::getInstance();  

  112. //$list = $db->select('demo',array('name'=>'tom','password'=>'ds'),array('name','password'));  

  113. //echo $db->insert('demo',array('name'=>'最近你啦','password'=>'123'));  

  114. //echo $db->update('demo',array("name"=>'xxx',"password"=>'123'),array('id'=>1));  

  115. echo $db->delete('demo',array('id'=>'2'));  

  116. db::getLastSql();  

  117. echo "

    ";  

  118. ?>  


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/229174.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号