PHP对象的浅复制与深复制的实例详解?
原型模式
用原型实例指定创建对象的种类,并且通过拷贝这些原型创建新的对象
原型模式是基于深复制和浅复制的,在Java里面有2种复制:
浅复制
将一个对象复制之后,生成一个新的对象,新对象的所有成员变量(基本类型或引用类型)都含有与原
有对象相同的值,如果原有对象的成员变量是基本数据类型,就会将这个变量的值拷贝一份到新对象
里面,如果原有对象的成员变量是引用数据类型,那么这个引用指向的对象不会新生成一份,而是,
在新对象里面的这个引用跟原有对象的引用指向的是同一个对象。
深复制
将一个对象复制之后,生成一个新的对象,新对象的基本数据类型变量含有与原有对象相同的值,如
果原有对象的成员变量是引用数据类型,在新对象里面,这些引用变量将指向被复制过的新对象,而
不再是指向原有的那些被引用的对象,深复制把要复制的对象所引用的对象都复制一遍。
比如:
有一个A对象,经过复制之后产生一个B对象,如果A里面有一个int型的变量i值为4,那么B对象里面
的inti的值也是4,A对这个int型变量的改变,不会影响B,如果A里面有一个成员变量c是引用类型
的,它指向了对象D,经过复制,B里面也会有一个c,这个c也指向D对象,A的c和B的c指向的是同一个
对象D,这就是浅复制。如果是深复制,A里面的c指向一个D对象,对于B里面的c会指向一个新的对象
,他们指向的不是同一个对象,这样,在原有对象里面对成员变量c指向的对象D做的任何改变,不会
影响新对象。
举个最简单的例子:
classA{
publicinti;
publicintj;
}
Aa=newA();
浅拷贝:
Aa1=a;
深拷贝:
Aa1=newA();
a1.i=a.i;
a1.j=a.j;
感觉如下:
浅拷贝只拷贝对象本身
深拷贝则拷贝对象中引用的对象,一直拷贝下去。
PHP基本公式?
下面主要讲述 round, floor, ceil, pow, rand,max, min, decbin, bindec, dechex, hexdec, decoct, octdec 函数。
round
round - 对浮点数进行四舍五入。round 函数语法如下:
round(float,precision)
其中参数 precision 表示小数点后面要保持的精度位数。如果不写参数 precision,表示四舍五入到整数位,比如:
echo round(3.4); // 3echo round(3.5); // 4echo round(3.6); // 4
如果 precision 为2,表示四舍五入到小数点后2位。示例如下:
echo round(1.95583, 2); // 1.96
在PHP中,可以利用算术运算符来实现加减乘除的计算公式,算术运算符用于将符号两边的数值进行运算,计算公式为“x + y”、“x - y”、“x * y”和“x / y”,分别表示两个数的和、差、积和商。
php到底怎么连接access数据库?
con\config.php 中配置如下 ?php return array( APP_DEBUG = true, DB_TYPE=pdo, // 注意DSN的配置针对不同的数据库有所区别 请参考PHP手册PDO类库部分DB_DSN=odbc:driver={microsoft access driver(*.mdb)};dbq=.getcwd().\\Database\\#fbdb.mdb, DB_USEcon\config.php 中配置如下 true,'DB_TYPE'=> 'pdo',// 注意DSN的配置针对不同的数据库有所区别 请参考PHP手册PDO类库部分'DB_DSN'=>"odbc:driver={microsoft access driver(*.mdb)};dbq=".getcwd()."\\Database\\#fbdb.mdb",'DB_USER'=>'root','DB_PWD'=>'','DB_PREFIX'=>'wxz_',);?>其中 需修改的有 "\\Database\\#fbdb.mdb"相对与当前目录下的数据库文件位置,其余的用户名、密码和前缀(“wxz_”)根据情况修改IndexAction.class.php示例代码query("select * from product"); print_r($r); }}ThinkPHP 内置了抽象数据库讵问层,把丌同癿数据库操作封装起来,我们叧需要使用公共癿Db 类迕行操作,而无需针对丌同癿数据库写丌同癿代码和底层实现,Db 类会自劢调用相应癿数据库驱劢来处理。目前癿数据库包括Mysql、SqlServer、PgSQL、Sqlite、Oracle、Ibase、Mongo,也包括对PDO 癿支持,如果应用需要使用数据库,必须配置数据库连接信息,数据库癿配置文件有多种定丿方式,不支持ACCESS数据库