php设计模式之单例模式

时间:2022-12-11 12:19:18

php设计模式之单例模式

简介

首先明确一下单例模式:如果希望在系统中某个类的对象只能存在一个,那么单例模式是最好的解决方案。

接下来让我们提炼出单例模式的几个关键点:假如有一个单例类,叫做 Singleton,那么:

1 singletonObj 对象应该可以被系统中的任何对象使用

2 singletonObj 对象不应该被存储在会被覆写的全局变量中

3 系统中不应超过一个singletonObj对象,也就是说 A对象可以设置singletonObj对象的一个属性,

而B对象不需要通过其他任何对象就可以直接获得该属性的值。

 

为了解决这个问题,那么我们就从问题本身入手,也就是如何控制一个类被实例化,

让该类的实例化只能实例化一次,这个听起来似乎真的有些难,但是实际上很简单,只需要定义一个私有的构造方法即可:

 

代码

 1 <?php
 2 /**
 3  * Created by PhpStorm.
 4  * User: evolution
 5  * Date: 14-12-7
 6  * Time: 下午2:40
 7  */
 8 class Singleton {
 9     //单一对象属性
10     private static $instance;
11     //定义一些全局变量需要存放属性
12     private $props = array();
13 
14     //私有的构造方法
15     private function __construct(){
16         echo 'into construct!';
17     }
18 
19     //返回单一实例
20     public static function getInstance () {
21         //判断是否已经有了实例化的对象
22         if(empty(self::$instance)) {
23             //可以被override (动态解析)
24             self::$instance = new static();
25             //不可以被override (静态解析)
26             //self::$instance = new self();
27         }
28 
29         return self::$instance;
30     }
31 
32     //设置属性
33     public function setProperty ( $key, $value) {
34         $this->props[$key] = $value;
35     }
36 
37     //获取属性
38     public function getPeoperty ( $key ) {
39         return $this->props[$key];
40     }
41 
42 }
43 
44 
45 $singleObj = Singleton::getInstance();
46 $singleObj->setProperty('root_path','/www');
47 $singleObj->setProperty('tmp_path','/tmp');
48 
49 //接下来删除该单例对象,如果还能获取到刚刚添加的属性,说明使用的是同一个对象
50 unset($singleObj);
51 
52 $singleObj = Singleton::getInstance();
53 echo $singleObj->getPeoperty('root_path');
54 echo $singleObj->getPeoperty('tmp_path');

 

实例

单例模式数据库处理类(只涉及到简单的原理)

 1 /**
 2  * 单例模式
 3  */
 4 class Db{
 5     private static $mysqli;//该类中的唯一一个实例
 6     private function __construct(){}//防止在外部实例化该类
 7     private function __clone(){}//禁止通过复制的方式实例化该类
 8     public static function connect(){//数据库连接方法
 9         self::$mysqli = new MySQLi("localhost","root","","test");
10         self::$mysqli->query("set names utf8");
11     }
12     public static function select($table){//数据库操作方法,后续可以继续完善和添加......
13         self::connect();
14         $result = self::$mysqli->query("select * from ".$table);
15         $result_arr = array();
16         while($query = $result->fetch_assoc()){
17             $result_arr[]    = $query;
18         }
19         return $result_arr;//结果集以数组的形式返回
20     }
21 }
22 $result = Db::select("article");
23 echo '<pre>';
24 print_r($result);
25 echo '</pre>';