两者在php手册上的解释是:
serialize — Generates a storable representation of a value
serialize — 产生一个可存储的值的表示
unserialize — Creates a PHP value from a stored representation
unserialize — 从已存储的表示中创建 PHP 的值
serialize,翻译过来叫“连载, 使连续”,通常称它为“序列化”,函数返回一个字符串,此字符串包含了表示value的字节流,可以存储于任何地方。这有利于存储或传递 PHP 的值,同时不丢失其类型和结构。serialize()可处理除了resource之外的任何类型。甚至可以serialize()那些包含了指向其自身引用的数组。你正serialize()的数组/对象中的引用也将被存储。当序列化对象时,PHP 将试图在序列动作之前调用该对象的成员函数__sleep()。这样就允许对象在被序列化之前做任何清除操作。
要将已序列化的字符串变回 PHP 的值,可使用unserialize()。类似的,当使用unserialize()恢复对象时, 将调用__wakeup()成员函数。
注:在 PHP 3 中,对象属性将被序列化,但是方法则会丢失。PHP 4 打破了此限制,可以同时存储属性和方法。请参见类与对象中的序列化对象部分获取更多信息。
serialize用于复杂数据的持久化
example
$array = array();
$array_b['key_a'] = 'we:bsite';
$array_b['value']= array(
7=>9.7);
$array_b['d']=3;
$array_b[1]=8;
$m_a = serialize($array_b);
echo $m_a,"\n";
unset($array);
$b = unserialize($m_a);
print_r($b);
执行结果
a:4:{s:5:"key_a";s:8:"we:bsite";s:5:"value";a:1:{i:7;d:9.699999999999999289457264239899814128875732421875;}s:1:"d";i:3;i:1;i:8;}
Array
(
[key_a] => we:bsite
[value] => Array
(
[7] => 9.7
)
[d] => 3
[1] => 8
)
//声明一个类
class dog {
var $name;
var $age;
var $owner;
function dog($in_name="unnamed",$in_age="0",$in_owner="unknown") {
$this->name = $in_name;
$this->age = $in_age;
$this->owner = $in_owner;
}
function getage() {return ($this->age * 365);}
function getowner() {return ($this->owner);}
function getname() {return ($this->name);}
}
$ourfirstdog = new dog("Rover",12,"Lisa and Graham");
//用serialize 函数将这个实例转化为一个序列化的字符串
$dogdisc = serialize($ourfirstdog);
echo $dogdisc,"\n";
O:3:"dog":3:{s:4:"name";s:5:"Rover";s:3:"age";i:12;s:5:"owner";s:15:"Lisa and Graham";}
/*可以将字符串 $dogdisc 存储到任何地方如 session,cookie,数据库,php文件*/
//注销这个类
unset($ourfirstdog);
/*将字符串 $dogdisc 从存储的地方读出来,如 session,cookie,数据库,php文件
并用 unserialize() 还原已经序列化的对象
还原的时候需要知道dog类的定义,否则会丢失类的接口,得到的只是一个
类定义未知的对象*/
$pet = unserialize($dogdisc); //此时的 $pet 已经是前面的 $ourfirstdog 对象了
//获得年龄和名字属性
$old = $pet->getage();
$name = $pet->getname();