PHP面向对象的工具

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();
原文地址:https://www.cnblogs.com/anyux/p/8269952.html