7.7.12 魔术方法__set_state()

7.7.12 魔术方法__set_state()

var_export() 函数

var_export() 函数返回关于传递给该函数的变量的结构信息,它和 var_dump() 类似,不同的是其返回的表示是合法的 PHP 代码。var_export必须返回合法的php代码, 也就是说,var_export返回的代码,可以直接当作php代码赋值个一个变量。 而这个变量就会取得和被var_export一样的类型的值。

__set_state()

用var_export()输出一个对象时,__set_state()会被调用,输出内容以该魔术方法的返回值为准。

$test = new Test();
$b = var_export($test, true);
var_dump($b);

class Test {

public $a;
public static function __set_state($array) {
    $ab = new Test();
    $ab->a = 10;
    return $ab;
}

}

当调用var_export()时,这个静态 方法会被调用(自PHP 5.1.0起有效)。
本方法的唯一参数是一个数组,其中包含按array(’property’ => value, …)格式排列的类属性。

2.php

<?php
/*  
 *  魔术方法, 只有PHP语言中存在
 *
 *
 *   __construct()
 *
 *   __destruct()
 *
 *   __set()
 *
 *   __get()
 *
 *   __isset()
 *
 *   __unset()
 *
 *   1. 自动调用, 但不同的魔术方法,有自己的调时机
 *   2. 都是以"__"开始的方法
 *   3. 所有的魔术方法,方法名都是固定的
 *   4. 如果不写, 就不存在, 也就没有默认的功能
 *
 *  
 *
 *  __toString() 
 *
 *      1. 是在直接使用 echo print printf输出一个对象引用时,自动调用这个方法
 *      2. 将对象的基本信息放在__toString()方法内部, 形成自字符串返回。
 *      3. __toString()方法中, 不能有参数, 而且必须返回一个字符串
 *
 *
 *  克隆对象
 *      1. 使用clone这个关键 复制了一个对象  
 *
 *
 *      __clone()魔术方法
 *
 *      1. 是在克隆对象时,自动调用的方法
 *      2. 作用:和构造方法一样, 是对新克隆的对象进行初使化
 *      3. 在这个方法中$this代表的是副本, 所以就可以给所有副本的成员初使化
 *
 *   __call()
 *
 *      1. 就是在调用一个对象中不存的方法时,自动调用的方法
 *      2. 有两个参数, 第一个参数是, 调用的不存的方法的方法名, 第二个参数是,调用这个不存的方法的方法参数
 *      3. 作用:可以写提示,但这个不是主要的功能。 将方法的功能相似, 但方法名还要不同的, 就可以采用这个方式来完成
 *
 *  串行化(序列化)
 *
 *      1. 将对象转成字符串(不用看懂) ---  串行化
 *  
 *      __sleep() -- 在串行化时自动调用的方法
 *
 *      作用: 可以设置需要串行化的对象的属性
 *
 *      只要在这个方法中, 返回一个数组, 在数组中声明了那个属性名, 那个属性就会被串行化, 没有在这个数组中的就不被串行化。 默认这个方法, 全部属性都串行化
 *
 *
 *
 *      2. 将字符串转回对象           --- 返串行化
 *
 *          __wakeup() --- 在返串行化时自动调用的方法
 *
 *      
 *
 *      作用:对象串行化回来的对象,进行初使化用的和下面两个方法作用相似
 *
 *      __construct()
 *      __clone()
 *
 *  *
 *      注意(串行化的时机):
 *
 *      1. 将对象在网络中传输
 *      2. 将对象持久保存 
 *
 *      
 *    数组串行化 json  --- javascript object     
 *
 *
 *    1. eval()函数 --- 检查并执行PHP代码
 *
 *  $str = "echo 'abc';";


eval($str);


var_dump();
var_export();
 *
 */ 

    $arr = array("one"=>1, "two"=>"2222222", "three"=>333);

    var_dump($arr);

    echo '<br>';

    $a = eval('$b='.var_export($arr, true).";");


    var_dump($b);

    echo $b['one'];


    class Person {
        public $name;
        public $age;
        public $sex;    

        public $marr = array("aaa", "bbb", "ccc", "ddd", "www");

        function __construct($name, $age, $sex) {
            $this->name = $name;
            $this->age = $age;
            $this->sex = $sex;
        }

        function say() {
            echo "我的名子是:{$this->name},我的年龄是:{$this->age},我的性别是:{$this->sex}。<br>";
        }

        function __toString() {
            return "aaaaaaaaaaaaaaaaaaa<br>";
        }

        function __destruct() {
            echo "{$this->name} ###########<br>";
        }

        function __clone() {
            $this->name="克隆的";
            $this->age=0;
        }

        function __call($method, $args) {
            if(in_array($method, $this->marr)) {
                echo $args[0]."<br>";   
            }else{
                echo "你调用的方法{$method}()不存在!<br>";
            }
        }


        function __sleep() {
            echo "只串行化,name和age <br>";
            return array("name", "age");
        }

        function __wakeup() {
            echo "返串行化时自动调用我这个方法了<br>";

            $this->age = 12;
        }


/*
        function aaa($a) {
            echo $a;
        }

        function bbb($b) {
            echo $b;
        }

        function ccc($c) {
            echo $c;
        }

        function ddd($d) {
            echo $d;
        }
 */     
    }

<?php
/*  
 *  魔术方法, 只有PHP语言中存在
 *
 *
 *   __construct()
 *
 *   __destruct()
 *
 *   __set()
 *
 *   __get()
 *
 *   __isset()
 *
 *   __unset()
 *
 *   1. 自动调用, 但不同的魔术方法,有自己的调时机
 *   2. 都是以"__"开始的方法
 *   3. 所有的魔术方法,方法名都是固定的
 *   4. 如果不写, 就不存在, 也就没有默认的功能
 *
 *  
 *
 *  __toString() 
 *
 *      1. 是在直接使用 echo print printf输出一个对象引用时,自动调用这个方法
 *      2. 将对象的基本信息放在__toString()方法内部, 形成自字符串返回。
 *      3. __toString()方法中, 不能有参数, 而且必须返回一个字符串
 *
 *
 *  克隆对象
 *      1. 使用clone这个关键 复制了一个对象  
 *
 *
 *      __clone()魔术方法
 *
 *      1. 是在克隆对象时,自动调用的方法
 *      2. 作用:和构造方法一样, 是对新克隆的对象进行初使化
 *      3. 在这个方法中$this代表的是副本, 所以就可以给所有副本的成员初使化
 *
 *   __call()
 *
 *      1. 就是在调用一个对象中不存的方法时,自动调用的方法
 *      2. 有两个参数, 第一个参数是, 调用的不存的方法的方法名, 第二个参数是,调用这个不存的方法的方法参数
 *      3. 作用:可以写提示,但这个不是主要的功能。 将方法的功能相似, 但方法名还要不同的, 就可以采用这个方式来完成
 *
 *  串行化(序列化)
 *
 *      1. 将对象转成字符串(不用看懂) ---  串行化
 *  
 *      __sleep() -- 在串行化时自动调用的方法
 *
 *      作用: 可以设置需要串行化的对象的属性
 *
 *      只要在这个方法中, 返回一个数组, 在数组中声明了那个属性名, 那个属性就会被串行化, 没有在这个数组中的就不被串行化。 默认这个方法, 全部属性都串行化
 *
 *
 *
 *      2. 将字符串转回对象           --- 返串行化
 *
 *          __wakeup() --- 在返串行化时自动调用的方法
 *
 *      
 *
 *      作用:对象串行化回来的对象,进行初使化用的和下面两个方法作用相似
 *
 *      __construct()
 *      __clone()
 *
 *  *
 *      注意(串行化的时机):
 *
 *      1. 将对象在网络中传输
 *      2. 将对象持久保存 
 *
 *      
 *    数组串行化 json  --- javascript object     
 *
 *
 *    1. eval()函数 --- 检查并执行PHP代码
 *
 *  $str = "echo 'abc';";


eval($str);


var_dump();
var_export();

    __set_state() 方法 , 就是在使用var_export()方法时, 导出一个类的信息时自动调用的方法
 *
 */ 


    class Person {
        public $name;
        public $age;
        public $sex;    

        public $marr = array("aaa", "bbb", "ccc", "ddd", "www");

        function __construct($name, $age, $sex) {
            $this->name = $name;
            $this->age = $age;
            $this->sex = $sex;
        }

        function say() {
            echo "我的名子是:{$this->name},我的年龄是:{$this->age},我的性别是:{$this->sex}。<br>";
        }

        function __toString() {
            return "aaaaaaaaaaaaaaaaaaa<br>";
        }

        function __destruct() {
            echo "{$this->name} ###########<br>";
        }

        function __clone() {
            $this->name="克隆的";
            $this->age=0;
        }

        function __call($method, $args) {
            if(in_array($method, $this->marr)) {
                echo $args[0]."<br>";   
            }else{
                echo "你调用的方法{$method}()不存在!<br>";
            }
        }


        function __sleep() {
            echo "只串行化,name和age <br>";
            return array("name", "age");
        }

        function __wakeup() {
            echo "返串行化时自动调用我这个方法了<br>";

            $this->age = 12;
        }


        static function __set_state($arr) {
            $p = new Person("李四", 30, "女");

            $p->name=$arr['name'];
                $p->age = $arr['age'];  
            

            return $p;
        }

/*
        function aaa($a) {
            echo $a;
        }

        function bbb($b) {
            echo $b;
        }

        function ccc($c) {
            echo $c;
        }

        function ddd($d) {
            echo $d;
        }
 */     
    }

    $p = new Person("张三", 20, "男");
    
    $p->name="李小四";
    $p -> age= 33;


    eval('$b ='.var_export($p, true).";");

    var_dump($b);

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容