我正在研究PHP的转换机制,并且在将数组转换为对象时遇到了一个奇怪的情况
$o = (object) array('1'=>'/foo/bar'); $o = new stdClass(); var_dump($o);
据我了解,PHP属性必须使用与PHP变量相同的规则声明。也就是说,有效的变量名称以字母或下划线开头,后跟任意数量的字母,数字或下划线。但是,上面的代码产生以下输出
object(stdClass)#1 (1) { [1]=> string(8) "/foo/bar" }
当您尝试访问对象中的信息时,它真正变得很奇怪。
var_dump($o->1); // parse error var_dump($o->{'1'}); // NULL var_dump(get_object_vars($o)); //array(0) { }
无论如何,是否可以获得对象中var_dump报告的信息,还是只是在请求生命周期的剩余时间内被锁定了?(这的实际用法为零,我很好奇)
是的,除非将其强制转换回数组,否则它们只会被锁定。PHP中有一些小“ Gotchas”,例如,在较早的版本中,您可以将常量定义为数组,但是从不访问其元素。即使现在,您仍可以将常量定义为资源(例如define('MYSQL',mysql_connect());),尽管这会导致相当不可预测的行为,因此也应避免使用。
define('MYSQL',mysql_connect());
通常,如果可能的话,最好避免数组到对象的转换。如果你真的需要做到这一点,考虑创建一个新的实例stdClass手动,然后重命名所有的变量,例如_0,_1等等。
stdClass
_0
_1
$a = array('cat','dog','pheasant'); $o = new stdClass; foreach ($a as $k => $v) { if (is_numeric($k)) { $k = "_{$k}"; } $o->$k = $v; }
编辑:只是对该假设进行了另一项快速检验,是的,它们在对象上下文中正式“不存在”;数据已存储,但无法访问,因此是最终的私有成员。这是测试:
$a = array('one','two','three'); $o = (object)$a; var_dump(property_exists($o, 1), property_exists($o, '1'));
输出为:
bool(false) bool(false)
再次编辑:有趣的旁注,以下操作返回false:
$a = array('one','two','three','banana' => 'lime'); $b = array('one','two','banana' => 'lime'); $y = (object)$a; $z = (object)$b; var_dump($y == $z);