单例模式概念
单例模式是指整个应用中类只有一个对象实例的设计模式。
单例模式的特点
一个类在整个应用中只有一个实例
类必须自行创建这个实例
必须自行向整个系统提供这个实例
php中使用单例模式的原因
我用php大部分操作都是和各种数据库打交道,包括mysql,redis,memcache等各种关系型和非关系型数据库,所以一个应用中会 存在大量连接数据库的操作,如果不用单例模式,那每次都要new操作,但是每次new都会消耗大量的内存资源和系统资源,而且每次打开和关闭数据库连接都 是对数据库的一种极大考验和浪费。
需要一个保存类的唯一实例的静态成员变量(通常$instance为私有变量)
构造函数和克隆函数必须声明为私有的,为了防止外部程序new类从而失去单例模式意义
必须提供一个访问这个实例的公共静态方法,从而返回唯一实例的一个引用
代码如下 | 复制代码 |
//设计模式 //单例模式 都是使用同一个对象 //class Ren //{ // public $name; // private static $dx; //存储对象 // // private function __construct() // { // // } // // public static function DuiXiang() // { // if(empty(self::$dx)) // { // self:;$dx=new Ren(); // } // return self::$dx; // } //} // //$r= Ren::DuiXiang(); //把构造函数变为私有 //做了一个方法来间接造对象 //在该方法里面加限制 |
工厂类
是指包含一个专门用来创建其他对象的方法的类,工厂类在多态性编程实践中是至关重要的,它允许动态的替换类,修改配置,通常会使应用程序更加灵活,熟练掌握工厂模式高级PHP开发人员是很重要的。
工厂模式通常用来返回符合类似接口的不同的类,工厂的一种常见用法就是创建多态的提供者,从而允许我们基于应用程序逻辑或者配置设置来决定应实例化哪一个类,例如,可以使用这样的提供者来扩展一个类,而不需要重构应用程序的其他部分,从而使用新的扩展后的名称 。
通常,工厂模式有一个关键的构造,根据一般原则命名为Factory的静态方法,然而这只是一种原则,工厂方法可以任意命名,这个静态还可以接受任意数据的参数,必须返回一个对象。
代码如下 | 复制代码 |
classYunSuan { public$a; public$b; functionSuan() { echo"对两个数进行运算"; } classgongchang {//功能 : 给一个参数,返回一个对象 staticfunctionchanpin($name) { switch($name) { case"'+": returnnewjia(); break; case"-"; returnnewjian(); break; } } } $a=gongchang::chanpin("+"); |
小编给大家推荐的这篇文章介绍了替换php字符串中的单引号为双引号的方法,非常实用,有兴趣的同学快看看吧。
实例如下:
代码如下 | 复制代码 |
$param="{'id':', 'name':'hi'}";
$new= preg_replace('/\"/','"',$param); |
在处理大量数据的时候,或者同时对几个表操作,而这几个表的操作要求,要么都成功,要么都失败的时候,就需要用到事物,而PDO中提供的事物,一般可以满足需求。
本篇文章,只涉及一个小例子。
在向数据库导入一个表格的时候,难免excel文件中存在部分错误,如果用常规方法,将会导致,一部分插入了数据库,一部分没有插入,会带了很大的不便。
代码如下 | 复制代码 |
<?php header("Content-Type: text/html; charset=utf-8"); error_reporting(E_ALL ^ E_NOTICE); require_once'excel_reader2.php';//导入excel_reader文件 $data=newSpreadsheet_Excel_Reader();//创建对象 $data->setOutputEncoding('UTF-8');//设置编码格式 $data->read("example.xls");//读取excel文档*/ echo$hang=$data->sheets[0]['numRows']."行<br>";//读出一共几行 echo$lie=$data->sheets[0]['numCols']."列<br>";//读出一共几列 $dbms='mysql'; $dbname='biaoge'; $user='root'; $pwd='123456'; $host='localhost'; $dsn="$dbms:host=$host;dbname=$dbname"; try{ $pdo=newPDO($dsn,$user,$pwd); $pdo->exec("SET NAMES UTF8");//设置数据库编码 $pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);//异常模式 $pdo->beginTransaction();//开启事物 $query="INSERT INTO test SET id1=?,id2=?,id3=?,id4=?,id5=?";//预编译插入语句 $result=$pdo->prepare($query); // $result->execute(array("111","222","333","444","555")); // $pdo->commit(); for($i= 1;$i<=$hang;$i++) { $id1=$data->sheets[0]['cells'][$i][1]; $id2=$data->sheets[0]['cells'][$i][2]; $id3=$data->sheets[0]['cells'][$i][3]; $id4=$data->sheets[0]['cells'][$i][4]; $id5=$data->sheets[0]['cells'][$i][5]; $result->bindParam(1,$id1);//绑定参数 $result->bindParam(2,$id2);//绑定参数 $result->bindParam(3,$id3);//绑定参数 $result->bindParam(4,$id4);//绑定参数 $result->bindParam(5,$id5);//绑定参数 echo$result->execute();//执行插入操作 } $pdo->commit();//执行事物的提交操作*/ }catch(PDOException$e){ die("Error!: ".$e->getMessage().'<br>'); $pdo->rollBack();//执行事物的回滚操作 } |
补充:
异常模式将会创建一个PDOException,并设置errorCode属性,它可以将执行代码封装到一个try{}catch{}语句块中。未捕获的异常将会导致脚本中断,并显示堆栈跟踪让用户了解是哪里出现了问题。
除此之外:
警告模式会产生一个PHP警告,并设置errorCode属性。如果设置的是警告模式,那么除非明确的检查错误代码,否则程序将继续按照其方式运行。
在默认模式中设置PDOStatement对象的errorCode属性,但不进行其他任何操作。