有关类和对象的相关知识:
类的自动加载:
自动加载就是引入的文件放入,只要输入类名就可以实现引入文件中的方法,从而减少了工作量和代码量
做法1:使用__autoload魔术函数
例子:
function __autoload($MysqlDB){
require($MysqlDB.".class.php");
}
做法2:使用spl_autoload_register函数
作用是:代替__autoload函数,可以应文件分布多个目录中的情况
语法:
spl_autoload_regist(“函数名1”);
spl_autoload_regist(“函数名2”);
对象的复制(克隆)clone
主要克隆对象中的“非对象非资源”数据
浅克隆:
只能克隆对象中的“非对象非资源”数据:
深克隆:
人为的去复制潜克隆复制不了的数据
这样的话就需要对该对象类使用魔术方法:
__clone()
对象遍历:
使用的是foreach语句进行遍历
注意:1,只能遍历看得到的“属性”,而且必须在类里面
如果要全部遍历,例子如下:
如果只获取两个属性的数据,那么操作如下:
PHP内置标准类
内部没有定义任何属性,但是该类的属性可以使用,只适合纯字符下标数组
标量数据转换为对象:属性名为固定的“scalar”,值为该变量的值
类型约束:
只能将必须指定的类型存储在该相对应的类型数据中
int n1 = 1; //int整数类型变量
float f1 ; //float小数类型变量
bool function getConcat( string s1, string s2){。。。。} //两个形参是string,返回值也是bool型
对函数(或方法)的参数设定必须使用的类型。只能对对象,接口,数组和函数进行约束,如下所示:
function f1(类名 $p1){....}:参数只能使用该类的对象;
function f1(接口名 $p1){....}:参数只能使用实现该接口的对象;
function f1(array $p1){....}:参数只能使用数组;
function f1(callable $p1){....}:参数只能是一个函数或方法,也叫回调函数(方法)
与类有关的魔术常量
__CLASS__,:获取其所在的类的类名。
__METHOD__:获取其所在的方法的方法名。
echo __CLASS__; //输出“A”
echo __METHOD__; //输出“f1”
//注意:get_class()也可以得到类名,但其必须有个“对象”
序列化的做法:
1,$str = serialize($变量); //此时该变量的数据就变成了字符串,并存入变量$str1;
但通常的应用出,此时就应该将其保存为文件(或数据库),如下:
2,file_put_contents(“文本文件路径”, $str);
反序列化操作:
3,$str = file_get_contents(“文本文件路径”); //先从文本文件中取得内容
4,$v1 = unserialize( $str); //反序列化,此时$v1这个变量中存储的就是原来变量内容(和类型)
用到的描述方法有:
__sleep() 和 __wakeup()
__sleep()方法中可以进行一些数据(资源)的清理工作,并返回一个数组,该数组可以存储一些想要进行序列化的对象的属性——即可以挑选属性进行序列化。
__wakeup()方法中,可以在进行反序列化操作的时候进行某些有用的“数据恢复工作”,比如:连接数据库
这是“序列化”对象:
__tostring()方法
转换为字符串的方法
__invoke()方法
对象当作一个“方法”(函数)的时候,会自动调用该魔术方法。
一些有关类和对象的系统函数和运算符
class_exists(), :判断某个类是否存在(定义过)
interface_exists(), :判断接口是否存在
get_class():获取某个对象的“所属类名”
get_parent_class(), :获取某个对象的“所属父类的类名”
get_class_methods(), :获取一个类的所有方法,返回一个索引数组,就是这些方法的名字。
get_class_vars(), :获取一个类的所有属性,返回一个数组,下标为属性名,值为属性值。
get_declared_classes():获得所有声明过的类(含系统中的类)
is_object():判断是否对象
get_object_vars():获得对象的所有属性,返回一个数组,下标为属性名,值为属性值
运算符:
new:
instanceof: 判断一个对象是否是某个类的“实例”
面向对象3大思想特征介绍:
封装:把数据私有化,封闭起来 private
继承:子类继承父类的属性和方法
多态:一个对象相同的东西得到的结果不同