为什么PHP元素在引用元素时会被修改?

时间:2013-07-08 13:45:37

标签: php arrays reference php-internals

当引用数组的元素时,数组的内容被修改:

$arr = array(100, 200);
var_dump($arr);
/* shows:
array(2) {
  [0]=>
  int(100)  // ← ← ← int(100)
  [1]=>
  int(200)
}
*/

$r = &$arr[0];
var_dump($arr);
/* shows:
array(2) {
  [0]=>
  &int(100)  // ← ← ← &int(100)
  [1]=>
  int(200)
}
*/

Live run. (Zend Engine会运行正常,而HHVM会显示“进程退出代码153”。)

为什么要修改元素?

为什么我们会看到&int(100)而不是int(100)

这似乎很奇怪。这种奇怪的解释是什么?

1 个答案:

答案 0 :(得分:7)

我已经回答了一段时间,但现在找不到答案。我相信它是这样的:

引用只是符号表中相同值的“附加”条目。符号表只能指向,而不能指向值中的值。符号表不能指向数组中的索引,它只能指向一个值。因此,当您想要引用数组索引时,该索引处的值将从数组中取出,为其创建一个符号,并且数组中的插槽将获得对该值的引用:

$foo = array('bar');

symbol | value
-------+----------------
foo    | array(0 => bar)

$baz =& $foo[0];

symbol | value
-------+----------------
foo    | array(0 => $1)
baz    | $1
$1     | bar              <-- pseudo entry for value that can be referenced

因为这是不可能的:

symbol | value
-------+----------------
foo    | array(0 => bar)
baz    | &foo[0]          <-- not supported by symbol table

上面的$1只是一个任意选择的“伪”名称,它与实际的PHP语法或内部实际引用的值无关。

根据评论中的要求,这里符号表通常的行为与引用有关:

$a = 1;

symbol | value
-------+----------------
a      | 1


$b = 1;

symbol | value
-------+----------------
a      | 1
b      | 1


$c =& a;

symbol | value
-------+----------------
a, c   | 1
b      | 1