1.什么是单例模式?

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

2.单例模式的三个要点

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

private static $_instance;

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

private function __construct()
{
} private function __clone()
{
}

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

public static function getInstance(){

    if (!(self::$_instance instanceof self)) {
self::$_instance = new self();
}
return self::$_instance;
}

3.为什么要使用单例模式?

A.PHP缺点:

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

B.单例模式在PHP中的应用场合:

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

4.应用单例模式对数据库进行操作

/**
* 设计模式之单例模式(单例模式生成一个对象后,此对象可以被众多其它对象所使用)
* 使用场景:最常用的地方是数据库连接。
*
* $_instance 必须声明为 私有的静态变量
* 构造函数和析构函数 必须声明为 私有的,防止外部程序new类,从而失去单例模式的意义(减少内存消耗)
* getInstance()方法必须声明为 公有的,必须调用此方法,以返回实例的一个引用
*
* 知识:1.双冒号操作符(::)只能访问静态变量和静态函数;2.new实例化对象都会消耗内存
*/
class db { private $conn; /**
* 1.静态变量(static),保存全局实例
* 2.私有属性(private),为了避免类外直接 new实例化 调用
*/
private static $sql;
private static $_instance; /** 私有化构造函数,防止外界实例化对象 **/
private function __construct(){ require_once('db.config.php');
$this->conn = mysql_connect($conf['host'], $conf['user'], $conf['password']) OR die(mysql_error());
mysql_select_db($conf['database'], $this->conn) OR die(mysql_error()); mysql_query('SET NAMES '.$conf['charset'].';', $this->conn);
} /** 静态方法,单例访问统一入口 **/
public static function getInstance(){ if (!(self::$_instance instanceof self)) {
self::$_instance = new self();
}
return self::$_instance;
} /** 私有化克隆函数,防止外界克隆对象 **/
private function __clone(){} /** 解析条件语句 **/
private function _parseCondition($condition){ if(is_array($condition)){
$where = '';
foreach($condition as $k => $v){
$where.= "AND `".$k."` = '".$v."' ";
}
$where = '('.trim(ltrim($where, 'AND')).')';
}else{
$where = $condition;
}
return $where;
} /** 解析字段语句 **/
private function _parseFields($fields){ if(is_array($fields)){
$field = '';
foreach($fields as $rs){
$field .= ', `'.$rs.'`';
}
$field = trim(ltrim($field, ','));
}else{
$field = $fields;
}
return $field;
} /** 查询数据库 **/
public function select($table, $condition = array(), $field = array()){ $where = empty($condition) ? '' : ' WHERE '.$this->_parseCondition($condition);
$fields = empty($field) ? '*' : $this->_parseFields($field); self::$sql = 'SELECT '.$fields.' FROM '.$table.$where; $query = mysql_query(self::$sql, $this->conn);
$ary = array();
while($row = mysql_fetch_array($query, MYSQL_ASSOC)){
$ary[] = $row;
}
return $ary;
} /** 返回当前SQL语句 **/
public function getLastSql(){
return self::$sql;
}
}

5.测试代码

header('Content-Type:text/html; Charset=utf-8;');
$db = db::getInstance();
$list = $db->select('table', array(), array());
echo $db->getLastSql();
echo '<pre>';
print_r($list);
echo '</pre>';

注意:记得配置db.config.php的数据库数组值

PHP设计模式之单例模式(数据库访问)的更多相关文章

  1. 关于PHP建立数据库访问类的封装以及操作php单例模式连接数据库封装类

    建立数据库访问类的封装 <?php   class DBDA {     public $host = "localhost"; //服务器地址     public $ui ...

  2. 每天一个设计模式-4 单例模式(Singleton)

    每天一个设计模式-4 单例模式(Singleton) 1.实际生活的例子 有一天,你的自行车的某个螺丝钉松了,修车铺离你家比较远,而附近的五金店有卖扳手:因此,你决定去五金店买一个扳手,自己把螺丝钉固 ...

  3. PHP中的设计模式:单例模式(译)

    原文链接:http://coderoncode.com/2014/01/27/design-patterns-php-singletons.html 单例模式用于限制类实例化到单个对象,当整个系统只需 ...

  4. Java设计模式03:常用设计模式之单例模式(创建型模式)

    1.  Java之单例模式(Singleton Pattern ) 单例模式是一种常见的设计模式,单例模式分三种:懒汉式单例.饿汉式单例.登记式单例三种. 单例模式有一下特点: 1.单例类只能有一个实 ...

  5. php设计模式之单例模式

    单例模式顾名思义,就是只有一个实例.作为对象的创建模式, 单例模式确保某一个类只有一个实例,而且自行实例化并向整个系统提供这个实例. 单例模式的要点有三个: 一是某个类只能有一个实例: 二是它必须自行 ...

  6. php设计模式:单例模式

    前些日子开始着真正的去了解下设计模式,开始么,简单地从单例模式开始,当然网上看了一些资料,单例模式比较好理解,看看介绍,然后看看代码基本也就能够理解了,设计模式这些的花点心思基本的是能够理解的,当然要 ...

  7. python设计模式之单例模式(一)

    前言 单例模式是创建模式中比较常见和常用的模式,在程序执行的整个生命周期只存在一个实例对象. 系列文章 python设计模式之单例模式(一) python设计模式之常用创建模式总结(二) python ...

  8. 数据库访问工具 DBUtl(公孙二狗)

    数据库访问工具 DBUtil DBUtil 用于简化数据库的访问,只要准备好配置文件,调用 DBUtil 的静态函数就能直接得到查询数据库的结果. 本文主要内容有: 数据库访问的思考 DBUtil 实 ...

  9. [PHP]PHP设计模式:单例模式

    单例模式(职责模式): 简单的说,一个对象(在学习设计模式之前,需要比较了解面向对象思想)只负责一个特定的任务: 单例类: 1.构造函数需要标记为private(访问控制:防止外部代码使用new操作符 ...

随机推荐

  1. JavaScript 【 IE中的XML DOM 】

    IE中的 XML DOM 在统一的正式规范出来以前,浏览器对于XML的解决方案各不相同.DOM2级提出了动态创建XML DOM规范,DOM3进一步增强了XML DOM.所以,在不同的浏览器实现XML的 ...

  2. asp.net几种<% %>用法

    在asp.net应用程序中,在asp.net页面常用的<%@ %>.<%# %>.<%= %>.在全球化的项目中使用<%$ %>绑定资源项目,在asp. ...

  3. DBSCAN(Density-based spatial clustering of applications with noise)

    Density-based spatial clustering of applications with noise (DBSCAN) is a data clustering algorithm ...

  4. 设计模式之UML类图

    在学设计模式的过程中经常碰到各式各样的UML类图.那些眼花缭乱的符号有什么含义呢? 类图含义 类图中的关系 从网上找来一张图作为实例 依赖关系:比如动物依赖氧气和水,这里如学生要依赖自行车.用虚线箭头 ...

  5. zend studio 使用断点调试

    1, 下载 Xdebug 1 # 下载地址 2 # http://xdebug.org/download.php 3   4 # 寻找和自己所安装的 php 版本对应的 Xdebug 下载 5 # 对 ...

  6. 初学swift笔记 流程控制(五)

    import Foundation ; i<=; i++ { println(i) } let str1="adl;fjasdfl;ouewrouqwperuadf" for ...

  7. VB6.0 String 用法总结

    问题一 VB 去掉字符串的头尾的空格 使用trim() 如: trim(" hello world ")= "hello world" 问题二 判断一个字符串是 ...

  8. Spring+Spring MVC+MyBatis

    Spring+Spring MVC+MyBatis 目录 一.新建一个基于Maven的Web项目 二.创建数据库与表 三.添加依赖包 四.新建POJO实体层 五.新建MyBatis SQL映射层 六. ...

  9. Linux系统针对网卡中断的优化处理

    摘要: 中断: 当网卡接收到数据包后,会触发硬中断,通知CPU来收包.硬中断是一个CPU和网卡交互的过程.这其实会消耗CPU资源.特别是在使用速度极快的万兆网卡 之后,大量的网络交互使得CPU很大一部 ...

  10. Oracle EBS-SQL (WIP-4):检查检查成品标准作业是否勾选"固定"标识.sql

    select WE.DESCRIPTION                                                                   任务说明,        ...