php手册指出:
它可以清理对象而且是 应该返回一个数组 该对象的所有变量的名称 应序列化。
我理解这一点,如果有一个班级。像这样:
<?php
class Foo {
public $bar = 'bar';
public $baz = 'baz';
public function __sleep() {
return array('bar');
}
}
$obj = new Foo();
$serialized = serialize($obj);
$unserialized = unserialize($serialized);
var_dump($unserialized);
?>
它只会序列化对象和属性$ bar?像这样:
object(Foo)[2]
public 'bar' => string 'bar' (length=3)
但它返回:
object(Foo)[2]
public 'bar' => string 'bar' (length=3)
public 'baz' => string 'baz' (length=3)
我解释错了吗?或者我做错了什么或什么?
答案 0 :(得分:6)
反序列化会创建对象的新实例,并且由于您的类定义初始化了该属性,因此您将获得该属性的默认值。试试这个:
class Foo {
public $bar;
public $baz;
public function __sleep()
{
return array('bar');
}
}
$obj = new Foo();
$obj->bar = 'bar';
$obj->baz = 'baz';
$serialized = serialize($obj);
$unserialized = unserialize($serialized);
var_dump($unserialized);
编辑:或者,您可以vardump($ serialized)并看到其中没有baz。
答案 1 :(得分:1)
您正在为$ baz属性定义'baz'的初始值,因此当您反序列化时,PHP会使用该默认值重新创建baz,尽管它不是序列化对象的一部分。 如果你在序列化之前更改了baz的值,然后序列化/反序列化,它会将baz重置为默认值'baz',而不是你将其更改为的值。
class Foo {
public $bar = 'bar';
public $baz = 'baz';
public function __sleep() {
return array('bar');
}
}
$obj = new Foo();
$obj->baz = 'newbaz';
var_dump($obj);
$serialized = serialize($obj);
$unserialized = unserialize($serialized);
var_dump($unserialized);