将PHP中的引用添加到数组中会创建一个引用数组


Adding references in PHP to an array creates an array of references

不确定这是否被视为错误

$array = ['numbers' => [1, 2, 3]];
foreach ($array as &$numbers) {
    $numbers = [4, 5, 6];
}
var_dump($array);
modify_array($array);
var_dump($array);
function modify_array($array_arg)
{
    $array_arg['numbers'] = [1, 2, 3];
}

打印

array(1) {
  ["numbers"]=>
  &array(3) {
    [0]=>
    int(4)
    [1]=>
    int(5)
    [2]=>
    int(6)
  }
}
array(1) {
  ["numbers"]=>
  &array(3) {
    [0]=>
    int(1)
    [1]=>
    int(2)
    [2]=>
    int(3)
  }
}

请注意,$array不是通过引用modify_array()传递的,而是修改了嵌套数组。这听起来很合乎逻辑,但不确定这是否有记录!

如果您使用foreah和reference,则会阻止PHP复制数组,因此您正在处理原始数组。当您完成foreach循环时,应该在循环中使用unset()变量,因为它仍然保留在内存中。如果你不这样做,你会得到不可预测的结果,比如你的问题中出现的这个。即使在文档中,您也会收到警告:

警告$value和最后一个数组元素的引用即使在foreach循环之后仍然保留。建议通过以下方式销毁unset()

在这里,您可以找到foreach循环的非常好的例子,而无需取消设置。

因此,如果添加unset(),所有内容看起来都应该是

$array = ['numbers' => [1, 2, 3]];
foreach ($array as &$numbers) {
    $numbers = [4, 5, 6];
}
unset($numbers);
var_dump($array);
modify_array($array);
var_dump($array);
function modify_array($array_arg) {
    $array_arg['numbers'] = [1, 2, 3];
}

结果:

array(1) { ["numbers"]=> array(3) { [0]=> int(4) [1]=> int(5) [2]=> int(6) } } 
array(1) { ["numbers"]=> array(3) { [0]=> int(4) [1]=> int(5) [2]=> int(6) } }

如果您重写以下代码:

foreach ($array as &$numbers) {
    $numbers = [4, 5, 6];
}

这样smth:

  $array['numbers'] = &$array['numbers'];
  $array['numbers'] = [4,5,6]; 

这样的行为会更容易理解,这似乎是一个已知的问题。(请参见:http://php.net/manual/en/language.references.php#87532)