Я видел это сегодня в некотором PHP-коде:
$items = $items ?: $this->_handle->result('next', $this->_result, $this);
Я не знаком с оператором ?:
Здесь. Он выглядит как тернарный оператор, но выражение для оценки, если предикат является истинным, опущено. Что это значит?
Он оценивает левый операнд, если левый операнд правдив , а правый операнд – в противном случае.
В псевдокоде,
foo = bar ?: baz;
грубо решает
foo = bar ? bar : baz;
или
if (bar) { foo = bar; } else { foo = baz; }
с той разницей, что bar
будет оцениваться только один раз.
Вы также можете использовать это для «самопроверки» foo
как показано в приведенном выше примере кода:
foo = foo ?: bar;
Это присвоит bar
foo
если foo
имеет значение null или false, иначе он оставит foo
без изменений.
Еще несколько примеров:
<?php var_dump(5 ?: 0); // 5 var_dump(false ?: 0); // 0 var_dump(null ?: 'foo'); // 'foo' var_dump(true ?: 123); // true var_dump('rock' ?: 'roll'); // 'rock' ?>
Кстати, это называется оператором Элвиса .
См. Документы :
Начиная с PHP 5.3, можно исключить среднюю часть тернарного оператора. Expression
expr1 ?: expr3
возвращаетexpr1
еслиexpr1
значениеTRUE
иexpr3
противном случае.
Будьте осторожны с массивами. Мы должны написать контрольную переменную после ?
, потому как:
$params = ['param1' => 'value1', 'param2' => 'value2', 'param3' => 'value3',]; $param1 = isset($params['param1'])?:null; $param2 = !empty($params['param2'])?:null; $param3 = $params['param3']?:null; // get E_NOTICE, if $params['param3'] eq false var_dump($param1,$param2,$param3); true // would like to expect `value1` true // would like to expect `value2` param3 // properly, but problem above
обновленный
Из RFC. В будущем (в PHP 7) оператор Null Coalesce Operator сделает это, например:
$param1 = $params['param1'] ?? null; // Equivalent to: $param1 = isset($params['param1']) ? $params['param1'] : null;
Да, это новое в PHP 5.3. Он возвращает либо значение тестового выражения, если оно оценивается как TRUE, либо альтернативное значение, если оно оценивается как FALSE.
Еще одно важное соображение: Оператор Элвиса нарушает процесс токенизации Zend Opcache. Я нашел это трудным путем! Хотя это может быть исправлено в более поздних версиях, я могу подтвердить, что эта проблема существует в PHP 5.5.38 (с встроенным Zend Opcache v7.0.6-dev).
Если вы обнаружите, что некоторые из ваших файлов «отказываются» кэшироваться в Zend Opcache, это может быть одной из причин … Надеюсь, это поможет!