• 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();
  • 相关阅读:
    学习进度条54
    学习进度条53
    学习进度条52
    学习进度条51
    学习进度条50
    学习进度条49
    学习进度条48
    学习进度条47
    学习进度条45
    线程池中的阻塞队列选择
  • 原文地址:https://www.cnblogs.com/anyux/p/8269952.html
Copyright © 2020-2023  润新知