PHP.mk документација

Приоритет на операторите

Почист и полокален преглед на PHP референцата, со задржана структура од PHP.net и подобра читливост за примери, секции и белешки.

language.operators.precedence.php PHP.net прокси Преводот е вчитан
Оригинал на PHP.net
Патека language.operators.precedence.php Локална патека за оваа страница.
Извор php.net/manual/en Оригиналниот HTML се реупотребува и локално се стилизира.
Режим Прокси + преведен приказ Кодовите, табелите и белешките остануваат читливи во истиот тек.
Приоритет на операторите

Референца за `language.operators.precedence.php` со подобрена типографија и навигација.

language.operators.precedence.php

Приоритет на операторите

Преcedenceто на оператор го специфицира колку „цврсто“ ги поврзува двата изрази. На пример, во изразот 1 + 5 * 3, одговорот е 16 и не 18 бидејќи операторот за множење („*“) има поголема precedence од операторот за собирање („+"). Заградите може да се користат за да се присили precedence, доколку е потребно. На пример: (1 + 5) * 3 се проценува на 18.

Кога операторите имаат еднаква precedence, нивната асоцијативност одлучува како се групираат операторите. На пример „-" е лево-асоцијативен, така што 1 - 2 - 3 се групира како (1 - 2) - 3 и се проценува на -4. Од друга страна „=" е десно-асоцијативен, така што $a = $b = $c се групира како $a = ($b = $c).

Операторите со еднаква precedence кои се не-асоцијативни не можат да се користат еден до друг, на пример 1 < 2 > 1 е нелегален во PHP. Изразот 1 <= 1 == 1 од друга страна е легален, бидејќи == операторот има пониска precedence од <= operator.

Асоцијативноста е значајна само за бинарни (и тернарни) оператори. Унитарните оператори се или префикс или постфикс, така што оваа идеја не е применлива. На пример !!$a може да се групира само како !(!$a).

Употребата на загради, дури и кога не е строго неопходна, често може да ја зголеми читливоста на кодот со правење на групирањето експлицитно наместо потпирање на имплицитната precedence и асоцијативност на операторите.

Следната табела ги наведува операторите по редослед на precedence, со највисоко-прецедентните на врвот. Операторите на иста линија имаат еднаква precedence, во тој случај асоцијативноста одлучува за групирањето.

Приоритет на операторите
Асоцијативност Оператори Дополнителни информации
(н/а) clone new clone and new
right ** arithmetic
(н/а) + - ++ -- ~ (int) (float) (string) (array) (object) (bool) @ arithmetic (унарно + and -), increment/decrement, bitwise, (унарно and пренесување тип
left instanceof type
(н/а) ! logical
left * / % arithmetic
left + - . arithmetic контрола на грешки + and -), array and string (. (бинарно
left << >> bitwise
left . string (пред PHP 8.0.0)
left |> pipe
non-associative < <= > >= comparison
non-associative == != === !== <> <=> comparison
left & bitwise and references
left ^ bitwise
left | bitwise
left && logical
left || logical
right ?? (од PHP 8.0.0)
non-associative ? : ternary null coalescing
right = += -= *= **= /= .= %= &= |= ^= <<= >>= ??= assignment
(н/а) yield from \t \r\n
(н/а) yield yield
(н/а) print print
left and logical
left xor logical
left or logical
(н/а) throw throw

(лево-асоцијативно пред PHP 8.0.0)

<?php
$a
= 3 * 3 % 5; // (3 * 3) % 5 = 4
var_dump($a);

$a = 1;
$b = 2;
$a = $b += 3; // $a = ($b += 3) -> $a = 5, $b = 5
var_dump($a, $b);
?>

Пример #1 Асоцијативност

Тернерниот оператор специфично бара употреба на загради за да се разјасни приоритетот.

<?php
$a
= true ? 0 : (true ? 1 : 2);
var_dump($a);

// this is not allowed since PHP 8
// $a = true ? 0 : true ? 1 : 2;
?>

Пример #2 Експлицитен приоритет

Приоритетот и асоцијативноста на операторите само ја одредуваат групираноста на изразите, тие не специфицираат ред на евалуација. PHP генерално не специфицира по кој редослед се евалуира изразот и треба да се избегнува код што претпоставува специфичен редослед на евалуација, бидејќи однесувањето може да се промени помеѓу верзиите на PHP или во зависност од околниот код.

<?php
$a
= 1;
echo
$a + $a++; // may print either 2 or 3

$i = 1;
$array[$i] = $i++; // may set either index 1 or 2
?>

Пример #4 +, - and . precedence

<?php
$x
= 4;
// this line might result in unexpected output:
echo "x minus one equals " . $x-1 . ", or so I hope\n";

// the desired precedence can be enforced by using parentheses:
echo "x minus one equals " . ($x-1) . ", or so I hope\n";

// this is not allowed, and throws a TypeError:
echo (("x minus one equals " . $x) - 1) . ", or so I hope\n";
?>

Пример #1 Пример што покажува затворачка ознака што го опфаќа последниот нов ред

-1, or so I hope
-1, or so I hope
Fatal error: Uncaught TypeError: Unsupported operand types: string - int

Пример #3 Недефиниран редослед на евалуација +, - and . Пример #5 Пред PHP 8,

<?php
$x
= 4;
// this line might result in unexpected output:
echo "x minus one equals " . $x-1 . ", or so I hope\n";

// because it is evaluated like this line (prior to PHP 8.0.0):
echo (("x minus one equals " . $x) - 1) . ", or so I hope\n";

// the desired precedence can be enforced by using parentheses:
echo "x minus one equals " . ($x-1) . ", or so I hope\n";
?>

Пример #1 Пример што покажува затворачка ознака што го опфаќа последниот нов ред

-1, or so I hope
-1, or so I hope
x minus one equals 3, or so I hope

Забелешка:

Иако = имаше ист приоритет if (!$a = foo())има понизок приоритет од повеќето други оператори, PHP сепак ќе дозволи изрази слични на следниве: foo() , во кој случај вратената вредност од $a.

Дневник на промени

Верзија = NULL
8.0.0 се става во.Конкатенација на низи (+ and -) и битно поместување лево/десно (<< and >>и бинарни оператори за поместување лево/десно ( + and - ); претходно имаше ист приоритет како << and >>.
8.0.0 и повисок приоритет од? :Тернарниот оператор (
7.4.0 ) сега е не-асоцијативен; претходно беше лево-асоцијативен..Се препорачува да се потпирате на приоритетот на конкатенација на низи (+ or -) во однос на аритметичкото собирање/одземање (<< or >>) или бинарните оператори за поместување лево/десно (
7.4.0 ), т.е. нивно заедничко користење во израз без загради.? :Се препорачува да се потпирате на левата асоцијативност на тернарниот оператор (

Белешки од корисници 8 белешки

fabmlk
пред 10 години
Watch out for the difference of priority between 'and vs &&' or '|| vs or':
<?php
$bool = true && false;
var_dump($bool); // false, that's expected

$bool = true and false;
var_dump($bool); // true, ouch!
?>
Because 'and/or' have lower priority than '=' but '||/&&' have higher.
), т.е. вгнездување на повеќе тернарни оператори без загради.
3 години пред
Note that ?? has a low priority, so this can lead to unexpected results:

$a=[];
$a['aa']??'not set' 
--> not set (as expected)

but
"lets see if it is set".$a['aa']??'not set'
--> notice; undefined index aa
--> lets see if it is set

so you need to use parenthesis
"lets see if it is set".($a['aa']??'not set')
rvwoens at gmail dot com
пред 8 години
If you've come here looking for a full list of PHP operators, take note that the table here is *not* complete. There are some additional operators (or operator-ish punctuation tokens) that are not included here, such as "->", "::", and "...".

For a really comprehensive list, take a look at the "List of Parser Tokens" page: http://php.net/manual/en/tokens.php
aaronw at catalyst dot net dot nz
пред 13 години
Beware the unusual order of bit-wise operators and comparison operators, this has often lead to bugs in my experience. For instance:

<?php if ( $flags & MASK  == 1) do_something(); ?>

will not do what you might expect from other languages. Use

<?php if (($flags & MASK) == 1) do_something(); ?>

in PHP instead.
Carsten Milkau
пред 4 години
An easy trick to get the result of the left shift operation (<<), e.g.

15 << 2 = 15 * (2*2) = 60

15 << 3 = 15 * (2*2*2) = 120

15 << 5 = 15 * (2*2*2*2*2) = 480

and so on...

So it's:

(number on left) multiplied by (number on right) times 2.

The same goes for the right shift operator (>>), where:

(number on left) divided by (number on right) times 2 e.g.

15 >> 2 = (15/2)/2 = 7/2 = 3 (use floor values if result is in decimals).

35 >> 3 = (((35/2)/2)/2 = (17/2)/2 = 8/2 = 4
tlili dot mokhtar at gmail dot com
3 години пред
Using cast and ternary operator can be unclear,
(Useful to know with: declare(strict_types = 1) ). 
<?php
$num_str="5";

$i1 = (int)  isset($num_str) ? $num_str : 0;
$i2 = (int) (isset($num_str) ? $num_str : 0);
var_dump($i1);
var_dump($i2);
?>
Output:
string(1) "5"
int(5)
sangala at seznam dot cz
пред 8 години
<?php 
// Another tricky thing here is using && or || with ternary ?:
$x && $y ? $a : $b;  // ($x && $y) ? $a : $b;

// while:
$x and $y ? $a : $b;  // $x and ($y ? $a : $b);

?>
ivan at dilber dot info
пред 5 години
//incorrect
$a = true ? 0 : true ? 1 : 2; // (true ? 0 : true) ? 1 : 2 = 2
//Unparenthesized `a ? b : c ? d : e` is not supported. Use either `(a ? b : c) ? d : e` or `a ? b : (c ? d : e)` 
//correct
$a = (true ? 0 : true) ? 1 : 2; // (true ? 0 : true) ? 1 : 2 = 2

==> correction documentation.
На оваа страница

Автоматски outline од активната документација.

Насловите ќе се појават тука по вчитување.

Попрегледно читање

Примерите, changelog табелите и user notes се визуелно издвоени за да не се губат во долгата содржина.

Брз совет Користи го outline-от Скокни директно на главните секции од активната страница.
Извор Оригиналниот линк останува достапен Кога ти треба целосен upstream context, отвори го PHP.net во нов tab.