Php операция сравнения in
Операторы сравнения, как это видно из их названия, позволяют сравнивать между собой два значения.
Это в своем роде уникальные операции, потому что независимо от типов своих аргументов они всегда возвращают одно из двух: false или true. Операции сравнения позволяют сравнивать два значения между собой и, если условие выполнено, возвращают true, а если нет — false.
В PHP разрешается сравнивать только скалярные переменные. Массивы и объекты в PHP сравнивать нельзя. Их даже нельзя сравнивать на равенство (при помощи оператора ==), но при выполнении такой операции PHP не выдает предупреждения. Так что удивившись как-то раз, почему два совершенно разных массива при сравнении их с помощью == оказываются вдруг одинаковыми, вспомните, что перед сравнением оба операнда преобразуются в слово array, которое потом и сравнивается.
Подробно о сравнении массивов смотрите здесь.
Также вам возможно будет интересно ознакомиться с разделом сравнение типов, в котором приведено большое количество соответствующих примеров.
Пример | Название | Результат |
---|---|---|
$a == $b | Равно | TRUE если $a равно $b. |
$a === $b | Тождественно равно | TRUE если $a равно $b и имеет тот же тип. (Добавлено в PHP 4) |
$a != $b | Не равно | TRUE если $a не равно $b. |
$a <> $b | Не равно | TRUE если $a не равно $b. |
$a !== $b | Тождественно не равно | TRUE если $a не равно $b или в случае, если они разных типов (Добавлено в PHP 4) |
$a TRUE если $a строго меньше $b. | ||
$a > $b | Больше | TRUE если $a строго больше $b. |
$a TRUE если $a is меньше или равно $b. | ||
$a >= $b | Больше или равно | TRUE если $a больше или равно $b. |
В случае, если вы сравниваете целое со строкой, строка будет преобразована к числу. В случае, если вы сравниваете две числовые строки, они сравниваются как целые числа.
( 0 == «a» ); // 0 == 0 -> true
var_dump ( «1» == «01» ); // 1 == 1 -> true
switch ( «a» ) <
case 0 :
echo «0» ;
break;
case «a» : // Эта ветка никогда не будет достигнута, так как «a» уже сопоставленно с 0
echo «a» ;
break;
>
?>
Еще одним условным оператором является «?«:
// Пример использования тернарного оператора
$action = (empty( $_POST [ ‘action’ ])) ? ‘default’ : $_POST [ ‘action’ ];
// Приведенный выше код аналогичен следующему блоку с использованием if/else
if (empty( $_POST [ ‘action’ ])) <
$action = ‘default’ ;
> else <
$action = $_POST [ ‘action’ ];
>
?>
Выражение (expr1) ? (expr2) : (expr3) интерпретируется как expr2 , если expr1 вычисляется в TRUE , или как expr3 если expr1 вычисляется в FALSE .
Источник
Php операция сравнения in
Для осуществления существуют различные группы .
Оператором называется нечто, состоящее из одного или более значений (выражений, если говорить на жаргоне программирования), которое можно вычислить как новое значение (таким образом, вся конструкция может рассматриваться как выражение). Отсюда следует, что функции или любые другие конструкции, которые возвращают значение (например, print()) являются операторами, в отличие от всех остальных языковых конструкций (например, echo()), которые ничего не возвращают.
Арифметические операции в PHP
Помните школьные основы арифметики? Описанные ниже операторы работают так же.
Пример | Название | Результат |
---|---|---|
-$a | Отрицание | Смена знака $a. |
$a + $b | Сложение | Сумма $a и $b. |
$a — $b | Вычитание | Разность $a и $b. |
$a * $b | Умножение | Произведение $a и $b. |
$a / $b | Деление | Частное от деления $a на $b. |
$a % $b | Деление по модулю | Целочисленный остаток от деления $a на $b. |
Операция деления («/») всегда возвращает вещественный тип, даже если оба значения были целочисленными (или строками, которые преобразуются в целые числа). В противном случае результат будет дробным.
Операция вычисления остатка от деления «%» работает только с целыми числами, так что применение ее к дробным может привести к нежелательному результату.
Возможно использование скобок. Приоритет одних математических операций над другими и изменение приоритетов при использовании скобок в арифметических выражениях соответствуют обычным математическим правилам.
Операции инкремента и декремента
PHP, аналогично C, поддерживает префиксные и постфиксные операторы инкремента и декремента.
Пример | Название | Действие |
---|---|---|
++$a | Префиксный инкремент | Увеличивает $a на единицу и возвращает значение $a. |
$a++ | Постфиксный инкремент | Возвращает значение $a, а затем увеличивает $a на единицу. |
—$a | Префиксный декремент | Уменьшает $a на единицу и возвращает значение $a. |
$a— | Постфиксный декремент | Возвращает значение $a, а затем уменьшает $a на единицу. |
Постфиксные операторы инкремента и декремента
Как и в языке Си, эти операторы увеличивают или уменьшают значение переменной, а в выражении возвращают значение переменной $a до изменения. Например:
$a=10;
$b=$a++;
echo «a=$a, b=$b»; // Выводит a=11, b=10
Как видите, сначала переменной $b присвоилось значение переменной $a, а уж затем последняя была инкрементирована. Впрочем, выражение, значение которого присваивается переменной $b, может быть и сложнее — в любом случае, инкремент $a произойдет только после его вычисления.
Префиксные операторы инкремента и декремента
Существуют также операторы инкремента и декремента, которые указываются , а не после имени переменной. Соответственно, и возвращают они значение переменной уже после изменения. Пример:
$a=10;
$b=—$a;
echo «a=$a, b=$b»; // Выводит a=9, b=9
Операции инкремента и декремента на практике применяются очень часто. Например, они встречаются практически в любом цикле for.
Постфиксный инкремент
» ;
$a = 5 ;
echo «Должно быть 5: » . $a ++ . «
\n» ;
echo «Должно быть 6: » . $a . «
\n» ;
Префиксный инкремент
» ;
$a = 5 ;
echo «Должно быть 6: » . ++ $a . «
\n» ;
echo «Должно быть 6: » . $a . «
\n» ;
Постфиксный декремент
» ;
$a = 5 ;
echo «Должно быть 5: » . $a — . «
\n» ;
echo «Должно быть 4: » . $a . «
\n» ;
Префиксный декремент
Булевые типы не подлежат инкрементированию и декрементированию.
Операции присвоения
Базовый оператор присвоения обозначается как = . На первый взгляд может показаться, что это оператор «равно». На самом деле это не так. В действительности, оператор присвоения означает, что левый операнд получает значение правого выражения, (т.е. устанавливается результирующим значением).
Результатом выполнения оператора присвоения является само присвоенное значение. Таким образом, результат выполнения $a = 3 будет равен 3 . Это позволяет использовать конструкции вида:
= ( $b = 4 ) + 5 ; // результат: $a установлена значением 9, переменной $b присвоено 4.
В дополнение к базовому оператору присвоения имеются «комбинированные операторы» для всех бинарных арифметических и строковых операций, которые позволяют использовать некоторое значение в выражении, а затем установить его как результат данного выражения. Например:
= 3 ;
$a += 5 ; // устанавливает $a значением 8, аналогично записи: $a = $a + 5;
$b = «Hello » ;
$b .= «There!» ; // устанавливает $b строкой «Hello There!», как и $b = $b . «There!»;
Обратите внимание, что присвоение копирует оригинальную переменную в новую (присвоение по значению), таким образом все последующие изменения одной из переменных на другой никак не отражаются. Начиная с PHP 4, также поддерживается присваивание по ссылке, используя синтаксис $var = &$othervar; ‘Присвоение по ссылке’ означает, что обе переменные указывают на одни и те же данные и никакого копирования не происходит. Подробно о ссылках вы можете узнать здесь.
Строковые операции
В PHP есть два оператора для работы со строками. Первый — оператор конкатенации (‘.’), который возвращает объединение левого и правого аргумента. Второй — оператор присвоения с конкатенацией, который присоединяет правый аргумент к левому. Приведем конкретный пример:
= «Hello » ;
$b = $a . «World!» ; // $b содержит строку «Hello World!»
$a = «Hello » ;
$a .= «World!» ; // $a содержит строку «Hello World!»
?>
Побитовые операции
Эти операции предназначены для работы (установки/снятия/проверки) групп битов в целой переменной. Биты целого числа — это не что иное, как отдельные разряды того же самого числа, записанного в двоичной системе счисления. Например, в двоичной системе число 12 будет выглядеть как 1100, а 2 — как 10, так что выражение 12|2 вернет нам число 14 (1110 в двоичной записи). Если переменная не целая, то она вна-
чале округляется, а уж затем к ней применяются перечисленные ниже операторы.
Для представления одного числа используются 32 бита:
- 0000 0000 0000 0000 0000 0000 0000 0000 — это ноль;
- 0000 0000 0000 0000 0000 0000 0000 0001 — это 1;
- 0000 0000 0000 0000 0000 0000 0000 0010 — это 2;
- 0000 0000 0000 0000 0000 0000 0000 0011 — это 3;
- 0000 0000 0000 0000 0000 0000 0000 0100 — это 4;
- 0000 0000 0000 0000 0000 0000 0000 0101 — это 5;
- .
- 0000 0000 0000 0000 0000 0000 0000 1111 — это 15;
- .
Пример | Название | Результат |
---|---|---|
$a & $b | Побитовое ‘и’ | Устанавливаются только те биты, которые установлены и в $a, и в $b. |
$a | $b | Побитовое ‘или’ | Устанавливаются те биты, которые установлены либо в $a, либо в $b. |
$a ^ $b | Исключающее или | Устанавливаются только те биты, которые установлены либо только в $a, либо только в $b |
Отрицание | Устанавливаются те биты, которые в $a не установлены, и наоборот. | |
$a > $b | Сдвиг вправо | Все биты переменной $a сдвигаються на $b позиций вправо (каждая позиция подразумевает ‘деление на 2’) |
Операции сравнения
Операторы сравнения, как это видно из их названия, позволяют сравнивать между собой два значения.
Это в своем роде уникальные операции, потому что независимо от типов своих аргументов они всегда возвращают одно из двух: false или true. Операции сравнения позволяют сравнивать два значения между собой и, если условие выполнено, возвращают true, а если нет — false.
В PHP разрешается сравнивать только скалярные переменные. Массивы и объекты в PHP сравнивать нельзя. Их даже нельзя сравнивать на равенство (при помощи оператора ==), но при выполнении такой операции PHP не выдает предупреждения. Так что удивившись как-то раз, почему два совершенно разных массива при сравнении их с помощью == оказываются вдруг одинаковыми, вспомните, что перед сравнением оба операнда преобразуются в слово array, которое потом и сравнивается.
Подробно о сравнении массивов смотрите здесь.
Пример | Название | Результат |
---|---|---|
$a == $b | Равно | TRUE если $a равно $b. |
$a === $b | Тождественно равно | TRUE если $a равно $b и имеет тот же тип. (Добавлено в PHP 4) |
$a != $b | Не равно | TRUE если $a не равно $b. |
$a <> $b | Не равно | TRUE если $a не равно $b. |
$a !== $b | Тождественно не равно | TRUE если $a не равно $b или в случае, если они разных типов (Добавлено в PHP 4) |
$a TRUE если $a строго меньше $b. | ||
$a > $b | Больше | TRUE если $a строго больше $b. |
$a TRUE если $a is меньше или равно $b. | ||
$a >= $b | Больше или равно | TRUE если $a больше или равно $b. |
Логические операции
Логические операторы предназначены исключительно для работы с логическими выражениями и также возвращают false или true.
Приведем таблицу логических операторов PHP:
Пример | Название | Результат |
---|---|---|
$a and $b | Логическое ‘и’ | TRUE если и $a, и $b TRUE . |
$a or $b | Логическое ‘или’ | TRUE если или $a, или $b TRUE . |
$a xor $b | Исключающее ‘или’ | TRUE если $a, или $b TRUE , но не оба. |
! $a | Отрицание | TRUE если $a не TRUE . |
$a && $b | Логическое ‘и’ | TRUE если и $a, и $b TRUE . |
$a || $b | Логическое ‘или’ | TRUE если или $a, или $b TRUE . |
Следует заметить, что вычисление логических выражений, содержащих такие операторы, идет всегда слева направо, при этом, если результат уже очевиден (например, false&&что-то всегда дает false), то вычисления обрываются, даже если в выражении присутствуют вызовы функций. Например, в операторе $logic = 0&&(time()>100); стандартная функция time() никогда не будет вызвана.
Будьте осторожны с логическими операциями — не забывайте про удваивание символа. Обратите внимание, что, например, | и || — два совершенно разных оператора, один из которых может потенциально возвращать любое число, а второй — только false и true.
Операторы инкремента (++) и декремента (—) не работают с логическими переменными.
Операторы эквивалентности
В PHP, начиная с PHP4 есть оператор тождественного сравнения — тройной знак равенства ===,
или оператор проверки на . PHP довольно терпимо относится к тому, что строки неявно преобразуются в числа, и наоборот.
Например, следующий код выведет, что значения переменных равны:
$a=10;
$b=»10″;
if($a==$b) echo «a и b равны»; // Выводит «a и b равны»
И это несмотря на то, что переменная $a представляет собой число, а $b — строку. Пеперь рассмотрим несколько другой пример:
$a=0; // ноль
$b=»»; // пустая строка
if($a==$b) echo «a и b равны»; // Выводит «a и b равны»
Хотя $a и $b явно не равны даже в обычном понимании этого слова, скрипт заявит, что они совпадают. Почему так происходит? Дело в том, что если один из операндов логического оператора может трактоваться как число, то оба операнда трактуются как числа. При этом пустая строка превращается в 0, который затем и сравнивается с нулем. Неудивительно, что оператор echo срабатывает.
Проблему решает оператор эквивалентности === (тройное равенство). Он не только сравнивает два выражения, но также их типы. Перепишем наш пример с использованием этого оператора:
$a=0; // ноль
$b=»»; // пустая строка
if($a===$b) echo «a и b равны»; // Ничего не выводит
Вот теперь ничего выведено не будет. Но возможности оператора эквивалентности идут далеко за пределы сравнения простых переменных. С его помощью можно сравнивать также и массивы, объекты и т. д. Это бывает иногда очень удобно. Вот пример:
$a=array(’a’=>’aaa’);
$b=array(’b’=>’bbb’);
if($a==$b) echo «С использованием == a=b
«;
if($a===$b) echo «С использованием === a=b
«;
Если запустить представленный код, то будет выведено первое сообщение, но не второе.
Произойдет это по той причине, что, как мы уже говорили, операнды-массивы преобразуются в строки array, которые затем и будут сравниваться. Оператор === лишен этого недостатка, поэтому работает верно.
Для оператора === существует и его антипод — оператор !===
Операции с символьными переменными
PHP следует соглашениям Perl (в отличие от С) касательно выполнения арифметических операций с символьными переменными. Например в Perl ‘Z’+1 будет вычислено как ‘AA’ , в то время как в C ‘Z’+1 будет вычислено как ‘[‘ ( ord(‘Z’) == 90, ord(‘[‘) == 91 ). Следует учесть, что к символьным переменным можно применять операцию инкремента, в то время как операцию декремента применять нельзя.
= ‘W’ ;
for( $n = 0 ; $n 6 ; $n ++)
echo ++ $i . «\n» ;
/*
Результат работы будет следующий:
Приоритеты операторов PHP
Операторы с более высоким уровнем приоритета выполняются в первую очередь:
Источник
Php операция сравнения in
In response to Lawrence about || always returning a boolean:
you can also use the «elvis operator»:
which is useful in cases, where the left-hand side of the ternary operator is too long type, is too complex to calculate twice, or has side-effects.
It also combines nicely with the ?? operator, which is equivalent to an empty() check (both isset() and `!= false`):
$x->y ?? null ?: ‘fallback’;
empty($x->y) ? $x->y : ‘fallback’
$test = true and false; —> $test === true
$test = (true and false); —> $test === false
$test = true && false; —> $test === false
NOTE: this is due to the first line actually being
($test = true) and false;
due to «&&» having a higher precedence than «=» while «and» has a lower one
If you want to use the ‘||’ operator to set a default value, like this:
= $fruit || ‘apple’ ; //if $fruit evaluates to FALSE, then $a will be set to TRUE (because (bool)’apple’ == TRUE)
?>
instead, you have to use the ‘?:’ operator:
= ( $fruit ? $fruit : ‘apple’ ); //if $fruit evaluates to FALSE, then $a will be set to ‘apple’
?>
But $fruit will be evaluated twice, which is not desirable. For example fruit() will be called twice:
function fruit ( $confirm ) <
if( $confirm )
return ‘banana’ ;
>
$a = ( fruit ( 1 ) ? fruit ( 1 ) : ‘apple’ ); //fruit() will be called twice!
?>
But since «since PHP 5.3, it is possible to leave out the middle part of the ternary operator» (http://www.php.net/manual/en/language.operators.comparison.php#language.operators.comparison.ternary), now you can code like this:
= ( $fruit ? : ‘apple’ ); //this will evaluate $fruit only once, and if it evaluates to FALSE, then $a will be set to ‘apple’
?>
But remember that a non-empty string ‘0’ evaluates to FALSE!
= ‘1’ ;
$a = ( $fruit ? : ‘apple’ ); //this line will set $a to ‘1’
$fruit = ‘0’ ;
$a = ( $fruit ? : ‘apple’ ); //this line will set $a to ‘apple’, not ‘0’!
?>
To assign default value in variable assignation, the simpliest solution to me is:
= my_function () or $v = «default» ;
?>
It works because, first, $v is assigned the return value from my_function(), then this value is evaluated as a part of a logical operation:
* if the left side is false, null, 0, or an empty string, the right side must be evaluated and, again, because ‘or’ has low precedence, $v is assigned the string «default»
* if the left side is none of the previously mentioned values, the logical operation ends and $v keeps the return value from my_function()
This is almost the same as the solution from [phpnet at zc dot webhop dot net], except that his solution (parenthesis and double pipe) doesn’t take advantage of the «or» low precedence.
NOTE: «» (the empty string) is evaluated as a FALSE logical operand, so make sure that the empty string is not an acceptable value from my_function(). If you need to consider the empty string as an acceptable return value, you must go the classical «if» way.
Unlike C++ and related languages, side effects in the left operand may NOT be used in the right operand.
e.g. if ($a=1 && $a>0)
will produce an unassigned error if $a has not previously been assigned a value.
using NULL coalesce operator:
= true == false ?? ‘no’ ;
var_dump ( $nc ); // false
$nc = null ?? ‘yes’ ;
var_dump ( $nc ); // yes
$username = null == false ?? ‘no’ ;
var_dump ( $nc ); // true
$nc = $_GET [ ‘something’ ] ?? ‘default’ ;
var_dump ( $nc ); // default
$nc = !isset( $_GET [ ‘something’ ]) ?? ‘wtf’ ;
var_dump ( $nc ); // true
$nc = isset( $_GET [ ‘something’ ]) ?? ‘wtf’ ;
var_dump ( $nc ); // false
$_POST [ ‘second’ ] = ‘chain’ ;
$nc = $_GET [ ‘first’ ] ?? $_POST [ ‘second’ ] ?? $_REQUEST [ ‘third’ ] ?? ‘wtf’ ;
var_dump ( $nc ); // chain
?>
// __forFun .
// Example Logical `or` operator
$a = true; // true|false or something for test 🙂
$b = «I’m a string result»; // use|test `string` or `object`
// print result
var_dump($c); // «I’m a string result»
Источник