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);