$c1 = $v1 = array();
$v1['key'] = 'value';
echo '$c1 === $v1: ' . (($c1 === $v1) ? 'true' : 'false'); // prints false
$c1 === $v1为假.但为什么?似乎$v1自动设置为另一个数组,然后自动设置为origin数组.为什么会这样呢?
最初$c和$v1设置为相同的数组实例.因此,如果我突变$v1,则$c不应反映更改,因为它们被设置为同一数组实例.
解决方法:
它们将是不一样的,因为您显式地将它们设置为容纳不同的值.第一个为空,第二个为空.
不过,它们没有设置为相同的引用,因此它们是两个不同的变量-
$c1 = $v1 = array();
您创建两个不同的数组.如果要更改为1反映在两个数组中,则需要使用&作为参考.变量标识符前面的运算符,就像这样.
$v1 = array();
$c1 = &$v1; // $c1 is now a reference to $v1
$v1['key'] = 'value';
echo '$c1 === $v1: ' . (($c1 === $v1) ? 'true' : 'false'); // true!
请注意,在创建了要引用的变量之后,需要对其进行引用.
当使用像这样的引用时,它是双向的-对$v1的任何更改都将应用于$c1,反之亦然.因此它们是不同的变量,但是将始终具有相同的值.
上面的示例中的比较成立,是因为数组完全相同-不仅是通过引用,而且因为它们拥有相同的值和键.如果比较两个具有完全相同的值和完全相同的匹配键的未引用数组,那么您也将获得真正的相等性.
var_dump(array('foo') === array('bar')); // false; same keys, different values
var_dump(array('bar') === array('bar')); // true; same keys, same values
var_dump(array('bar') === array('baz' => 'bar')); // false; different keys, same value
标签:arrays,php
来源: https://codeday.me/bug/20191025/1932504.html