面向对象的工具

OOP的魔术方法

PHP通过类和方法等语言结构支持面向对象的编程。同时也通过对象相关的函数和内置类为面向对象提供广泛支持

__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();
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值