php通过类和方法等语言结构支持面向对象的编程。同时也通过对象相关的函数和内置类为面向对象提供广泛支持
OOP的魔术方法
__autoload()自动加载类方法
常规引入类文件的问题 1.如果要包含多个类文件,是不是全都引入? 2.引入多个类文件,如果有些用不到,就会产生浪费 3.引入了类文件,可能会遗漏,比如说,创建一个对象,而这个对象的类文件没有导入。就会产生错误 PHP引入了__autoload()内置方法来自动包含类文件。__autoload()应该被写成单个参数的方法。当PHP引擎遇到试图实例化未知类的操作时,会调用__autoload()方法,并将类名当作字符串参数传递给它.即当你试图实例化类时,会调用__autoload()方法,加载意图实例化的类文件 提示:此时要注意文件命令规范,一个类文件要以.class.php的后缀结尾
#文件名称 Computer.class.php 提示: 这里的Computer类名首字母大写 vim Computer.class.php class Computer{ public $_name = "联想"; public function __construct() { echo "<meta charset=utf8>"; } public function _run(){ return "我被运行了"; } } vim demo1.php function __autoload($_className){ require $_className.".class.php"; } $computer1 = new Computer(); echo $computer1->_name; echo $computer1->_run();
__call()屏蔽错误方法
//PHP采用了__call()内置方法屏蔽了对象调用方法时产生的错误,当对象调用一个不存在的方法时,会自动调用__call()方法。 提示:$methodName参数是一个字符串,$arguments是一个数组。私有方法,仅允许类内部调用
虽然在日志会出现警告信息,但是为了程序的安全性,可以忽略! class Computer{ public $_name = "联想"; public function __construct() { echo "<meta charset=utf8>"; } // $_methodname 是一个字符串 // $arguments 是一个参数数组 public function __call($_methodname, $arguments) { echo $_methodname ."方法错误,您调用的方法不存在,请查看当前类是否存在此方法<br>"; print_r($arguments); } } $computer1 = new Computer(); echo $computer1->_name; // 调用一个不存在的方法,并写入参数 $computer1->_run("张三","开启","笔记本","开启win7系统");
__toString()打印对象的引用
//PHP使用__toString()内置方法来打印对象的引用。没有使用__toString()的对象是产生一个错误,当打印对象的时候会自动调用__toString()方法。 提示:为了安全,应当设置为私有方法,仅允许类内部调用 class Computer{ public $_name = "联想"; public function __construct() { echo "<meta charset=utf8>"; } private function __toString() { return "我是__toString方法运行的结果"; } } $computer1 = new Computer(); // 可以在输入一个对象的引用 echo $computer1; // 同样也可以在类实例化时输出 echo new Computer();
__clone()克隆方法
首先要对比下三种模式
#分别实例化对象 $computer1 = new Computer(); $computer2 = new Computer();
#实例化一个对象,将引用赋值给另一个变量 $computer1 = new Comoputer(); $computer2 = $computer1;
#克隆模式 $computer1 = new Computer(); $computer2 = clone $computer1;
// PHP可以在类中定义一个__clone()内置方法来调整对象的克隆行为。当一个对象被克隆的时候自动执行__clone()方法,而复制的对象可以在其方法体内进行调整。 class Computer{ public $_name = "联想"; public function __construct() { echo "<meta charset=utf8>"; } public function _run(){ echo $this->_name; } public function __clone() { $this->_name="IBM"; } } function diffComputer() { $computer1 = new Computer(); $computer1->_name = "DELL"; $computer2 = new Computer(); $computer1->_run(); $computer2->_run(); } function transComputer(){ $computer1= new Computer(); $computer2 = $computer1; $computer1->_name="DELL"; $computer2->_run(); } function cloneComputer(){ $computer1 = new Computer(); // 此时仅克隆了 $computer1为 $computer2 // 克隆后在当前时刻即将 $computer2指向堆内存中_name字段修改为 "IBM" 克隆函数中已定义 // 即可以理解为 在克隆的同时已修改了堆内存的属性 $computer2 = clone $computer1; $computer2->_run(); $computer1->_run(); } echo "diffComputer function====>"; diffComputer(); echo "<br>"; echo "transComputer function=====>"; transComputer(); echo "<br>"; 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();