面向对象
类的加载
1.类的手动加载:
手工指定加载类

2.使用class_exists()函数判断是否类存在再加载:

3. 自动加载:使用__autoload()函数(该函数逐步废弃,请更换函数):

4.自动加载需增加自动判断功能:

注意:自动加载是按照开发者规定的路径去寻找文件并实现包含.如果文件不存在会出错.
5.自定义机制注册函数spl_autoload_register函数:注册自定义的函数处理自动加载类
spl_autoload_register — 注册自定义的函数作为 __autoload 的实现

类的加载总结

补充:也可以写个类来实现类的加载

对象克隆
克隆对象就是复制对象
1.使用clone关键字克隆对象

2. 克隆出来的对象和原来的对象是两个不同的内存地址,属于两个不同的对象
3.克隆出来的对象会自动调用__clone方法(但不调用__construct方法)
<?php
class Pig{
public $name;
Public function __construct(){
echo __METHOD__;
var_dump($this);
}
public function __clone(){
echo __METHOD__;
var_dump($this);
}
}
//new实例化的对象自动调用构造方法(不调用克隆方法)
$p1 = new Pig();
//克隆的对象自动调用克隆方法(不调用构造方法)
$p2 = clone $p1;
$p1->name ='猪八戒';
$p2->name ='猪九戒';
var_dump($p1,$p2);//观察发现的确是两个不同的对象
运行效果如下:

4. private clone()方法禁止外部克隆对象
class TheClass{
//类内部插入1行private克隆方法即可禁止外部克隆对象
private function clone(){}
}
克隆对象总结

封装数据库操作类(暂略)
设计模式之单例模式
单例模式:singleton,一个类最多只有1个对象的设计.
1.首先定义1个空类singleton
2.禁止外部实例化对象:使用private构造方法

3.此时类的外部无法实例化对象,只能用类的静态方法
4.使用类的静态方法实例化对象并返回该实例给外部

5. 使用静态属性确保类只构造1次实例对象

6.再使用private克隆方法禁止克隆

现在类代码如下:

现在我们无论调用多少次类的静态方法都只会产生1个实例化对象.且private克隆方法禁用克隆也杜绝了复制对象的可能性.
单例模式总结

设计模式之工厂模式
定义:工厂模式,像工厂一样流水线生产对象.从而方便今后代码统一维护.而且工厂模式下可以方便隐藏真实类结构,因此也更加安全.
1.工厂模式针对是"相同模型"的统一产出.
即使用工厂模式的类应具有相同的结构或相似的功能.所以首先要有一批具有类似功能的类(其实本质是同样大类下的小类)

2. 针对相同的大类下的小类,使用工厂模式,增加一个工厂类:
HumanFactory类

我们现在用HumanFactory类来实例化男人女人人妖对象,而不是直接使用男人,女人,人妖类来实例化对象.
3.工厂类在生产对象的时候,额外产生1个工厂类对象,可优化为静态工厂

现在代码优化为静态工厂.我们使用静态工厂类来实例化男人女人人妖对象.
4.匿名工厂:工厂模式隐藏真实类名内部封装使用代号代替,方便日后统一维护也更安全

使用匿名工厂,调用工厂类的地方无需修改.一旦日后具体类如果有变动(比如更名),可在匿名工厂类中(switch语句块中)一次性修改即可.
工厂模式总结

本文介绍了PHP中类的手动及自动加载方式,包括使用__autoload()函数和spl_autoload_register()函数等,并探讨了对象克隆的过程及限制。此外,还详细讲解了单例模式和工厂模式的设计与应用。
1254

被折叠的 条评论
为什么被折叠?



