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::unserializeecho $newobj->getData();// 调用obj::getData// 执行结束,调用析构函数,先执行newobj对象的析构函数在执行obj对象的析构函数?> |
以上例子输出:
|
1
2
3
4
|
调用构造函数这是一段测试文字step:1 调用析构函数step:0 调用析构函数 |
原文链接:http://blog.csdn.net/wuxing26jiayou/article/details/51024120
© 版权声明
文章版权归作者所有,未经允许请勿转载。
THE END
















暂无评论内容