当引用数组的元素时,数组的内容被修改:
$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)
?
这似乎很奇怪。这种奇怪的解释是什么?
答案 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