PHP Serializable是自定义序列化的接口。实现此接口的类将不再支持__sleep()和__wakeup(),当类的实例被序列化时将自动调用serialize方法,并且不会调用 __destruct()或有其他影响。当类的实例被反序列化时,将调用unserialize()方法,并且不执行__construct()。接口摘要如下:
1
2
3
4
|
Serializable { abstract public string serialize ( void ) abstract public mixed unserialize ( string $serialized ) } |
例子说明:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
|
<?php /** * 类自定义序列化相关操作 * * @author 疯狂老司机 */ class obj implements Serializable { private $data ; private $step = 0; /* * 构造函数 */ public function __construct() { $this ->data = "这是一段测试文字<br>" ; echo '调用构造函数<br>' ; } public function serialize() { return serialize( $this ->data); } public function unserialize( $data ) { $this ->step++; $this ->data = unserialize( $data ); } /* * 析构函数 */ public function __destruct() { echo 'step:' . $this ->step. ' 调用析构函数<br>' ; } public function getData(){ return $this ->data; } } $obj = new obj; // 调用obj::__construct $ser = serialize( $obj ); // 调用obj::serialize $newobj = unserialize( $ser ); // 调用obj::unserialize echo $newobj ->getData(); // 调用obj::getData // 执行结束,调用析构函数,先执行newobj对象的析构函数在执行obj对象的析构函数 ?> |
以上例子输出:
1
2
3
4
|
调用构造函数 这是一段测试文字 step:1 调用析构函数 step:0 调用析构函数 |
原文链接:http://blog.csdn.net/wuxing26jiayou/article/details/51024120
© 版权声明
文章版权归作者所有,未经允许请勿转载。
THE END
暂无评论内容