Приоритет оператора говорит, что порядок должен быть: +, &, =
, Но это выполнение кода показывает, что порядок: &, =, +
$b = 1;
$a = & $b + print('print executed');
if ($a == 1)
echo ' but one was not added and error was not raised';
Выход print executed but one was not added and error was not raised
Почему приоритет меняется в этом случае?
Постскриптум
$a = new stdClass();
$c = &$a instanceof $a;
var_dump($c); // class stdClass#1 (0) {}
$b = $a instanceof $a;
var_dump($b); // bool(true)
Возможно, это действительно не отвечает на ваш вопрос, но рассмотрите этот код:
$b = 1;
$a = &$b + 123;
Коды операций раскрывают следующую стратегию исполнения:
compiled vars: !0 = $b, !1 = $a
line # * op fetch ext return operands
-----------------------------------------------------------------------------
3 0 > ASSIGN !0, 1
4 1 ASSIGN_REF $1 !1, !0
2 ADD ~2 $1, 123
3 FREE ~2
Как видите, присваивание по ссылке происходит, и сложение сохраняется во временной переменной, а затем освобождается; в основном неоперативный.
Возможно, документация могла бы быть более понятной, но я не могу представить сценарий, в котором этот конкретный код когда-либо имел бы смысл 🙂
Других решений пока нет …