PHP通过类和方法等语言结构支持面向对象的编程。同时也通过对象相关的函数和内置类为面向对象提供广泛支持
OOP的魔术方法
__autoload()自动加载类方法
常规引入类文件的问题1.如果要包含多个类文件,是不是全都引入?2.引入多个类文件,如果有些用不到,就会产生浪费3.引入了类文件,可能会遗漏,比如说,创建一个对象,而这个对象的类文件没有导入。就会产生错误
PHP引入了__autoload()内置方法来自动包含类文件。__autoload()应该被写成单个参数的方法。当PHP引擎遇到试图实例化未知类的操作时,会调用__autoload()方法,并将类名当作字符串参数传递给它.即当你试图实例化类时,会调用__autoload()方法,加载意图实例化的类文件
提示:此时要注意文件命令规范,一个类文件要以.class.php的后缀结尾
#文件名称 Computer.class.php
提示: 这里的Computer类名首字母大写
vim Computer.class.phpclassComputer{public $_name = "联想";public function__construct()
{echo "";
}public function_run(){return "我被运行了";
}
}
vim demo1.phpfunction __autoload($_className){require $_className.".class.php";
}$computer1 = newComputer();echo $computer1->_name;echo $computer1->_run();
__call()屏蔽错误方法
//PHP采用了__call()内置方法屏蔽了对象调用方法时产生的错误,当对象调用一个不存在的方法时,会自动调用__call()方法。
提示:$methodName参数是一个字符串,$arguments是一个数组。私有方法,仅允许类内部调用
虽然在日志会出现警告信息,但是为了程序的安全性,可以忽略!classComputer{public $_name = "联想";public function__construct()
{echo "";
}//$_methodname 是一个字符串
// $arguments 是一个参数数组
public function __call($_methodname, $arguments)
{echo $_methodname ."方法错误,您调用的方法不存在,请查看当前类是否存在此方法
";print_r($arguments);
}
}$computer1 = newComputer();echo $computer1->_name;//调用一个不存在的方法,并写入参数
$computer1->_run("张三","开启","笔记本","开启win7系统");
__toString()打印对象的引用
//PHP使用__toString()内置方法来打印对象的引用。没有使用__toString()的对象是产生一个错误,当打印对象的时候会自动调用__toString()方法。
提示:为了安全,应当设置为私有方法,仅允许类内部调用classComputer{public $_name = "联想";public function__construct()
{echo "";
}private function__toString()
{return "我是__toString方法运行的结果";
}
}$computer1 = newComputer();//可以在输入一个对象的引用
echo $computer1;//同样也可以在类实例化时输出
echo new Computer();
__clone()克隆方法
首先要对比下三种模式
#分别实例化对象
$computer1 = newComputer();$computer2 = new Computer();
#实例化一个对象,将引用赋值给另一个变量
$computer1 = newComoputer();$computer2 = $computer1;
#克隆模式
$computer1 = newComputer();$computer2 = clone $computer1;
//PHP可以在类中定义一个__clone()内置方法来调整对象的克隆行为。当一个对象被克隆的时候自动执行__clone()方法,而复制的对象可以在其方法体内进行调整。
classComputer{public $_name = "联想";public function__construct()
{echo "";
}public function_run(){echo $this->_name;
}public function__clone()
{$this->_name="IBM";
}
}functiondiffComputer()
{$computer1 = newComputer();$computer1->_name = "DELL";$computer2 = newComputer();$computer1->_run();$computer2->_run();
}functiontransComputer(){$computer1= newComputer();$computer2 = $computer1;$computer1->_name="DELL";$computer2->_run();
}functioncloneComputer(){$computer1 = newComputer();//此时仅克隆了 $computer1为 $computer2
// 克隆后在当前时刻即将 $computer2指向堆内存中_name字段修改为 "IBM" 克隆函数中已定义
// 即可以理解为 在克隆的同时已修改了堆内存的属性
$computer2 = clone $computer1;$computer2->_run();$computer1->_run();
}echo "diffComputer function====>";
diffComputer();echo "
";echo "transComputer function=====>";
transComputer();echo "
";echo "cloneCompuer function=====>";
cloneComputer();
类函数和对象函数
PHP提供了一系列强大的函数来检测类和对象。以便在第三方系统,运行时知道正在使用的是哪个。
//class_exists()函数接受表示类的字符串,检查并返回布尔值。如果类存在,返回true,否则返回false.
echo class_exists(‘Computer’);
//get_class()函数获取对象的类名,如果不是对象,则返回false.
echo get_class($computer);
//get_class_methods()函数获取类中的方法(公共的),以数组的形式返回出来。
print_r(get_class_methods($computer));
//get_class_vars()函数获取类中的字段(公共的),以数组的形式返回出来
print_r(get_class_vars(‘Computer‘));
//get_parent_class()函数获取子类的父类,如果没有返回false;
echo get_parent_class("NoteComputer");
//interface_exists()函数确定接口是否存在,如果存在返回true,否则返回false
echo interface_exists(‘Computer‘);
//is_a()函数确定对象是否是类或者这个类的父类时,返回true,否则返回false
echo is_a($computer."Computer");
//is_subclass_of()函数确定对象是否是类的子类,是返回true,否则返回false
echo is_subclass_of($NoteComputer,"Computer");
//method_exists()函数确定对象的方法是否存在,是返回true,否则返回false
echo method_exists($computer,‘_run‘);
OOP的反射API
//PHP5的类和对象并没有告诉我们类内部的一切,而只是报告了它们的公共成员。要充分了解一个类,需要知道其私有成员和保护成员,还要知道其方法所期望的参数,对此,使用反射API.
学习反射API可以翻阅PHP手册阅读Reflection这个类
//获得反射API的转储信息
$rc = new ReflectionClass("Computer");
Reflection::export($rc);
//获得PHP内置的类库的信息
Reflection::export(new ReflectionClass(‘Reflection‘));
//获取类里的某个元素
$_rc = new ReflectionClass(‘Comoputer‘);echo $_rc->getFileName();echo $_rc->getName();