LINUXSOFT.cz Přeskoč levou lištu
Uživatel: Heslo:  
   CZUKPL

> PHP (11) - Operátory porovnání; priorita operátorů

V dnešním díle našeho Mega-PHP seriálu se podíváme na zbytek operátorů, o kterých ještě nebyla řeč. Zmíním se i o prioritě operátorů.

14.6.2004 15:00 | Petr Zajíc | Články autora | přečteno 95564×

Komerční sdělení: Pořádáme Kurzy PHP

Většinu operátorů, které budete při práci s PHP potřebovat, jsme v tomto seriálu již probrali. Podívejme se teď na zbytek těch, které by se nám při práci s PHP mohly hodit.

Zatím jsme žili s PHP ve světě, v němž nebyla řeč o chybách. Chyby se ale v programování vyskytují a bude jim později věnován celý jeden článek seriálu. Nyní si uveďme, že PHP umí použít operátor zavináče před výrazem, což způsobí, že případná chyba při vyhodnocování tohoto výrazu bude neokázale ignorována. Příklad:

<?
echo 1/0; // skončí chybou Division by zero
echo @(1/0); // půjde dál
?>

Je to myslím dostatečně jasné. Jen dodejme, že zavináč nepatří před příkaz echo, protože echo je jazykový konstrukt a ne výraz. Chyby se ale vždy takto neřeší, je to jen jedna možnost. Více později.

Operátory porovnání

Jiná skupina operátorů, kterou jsme zatím vynechali, jsou porovnávací operátory. Protože fungují podobně jako v matematice, pojďme si nejprve ukázat příklad a pak probrat zvláštnosti:

<?
$a
=5; $b=6;
echo
$a<$b; // vrátí TRUE
echo $b>$a; // rovněž TRUE
echo $b>=$a;
echo
$a<=$b;
echo
$a<>$b; //nerovnost, stejné jako
echo $a!=$b;
?>

Tohle bylo snadné. Můžeme porovnávat proměnné pomocí rovnítka (=)? NE. V PHP, jak již bylo řečeno, slouží rovnítko k přiřazování, takže zápis $a=$b je sice možný, ale způsobí zkopírování "béčka" do "áčka" a ne jejich porovnání. Toto byste měli pochopit předtím, než začnete pracovat s porovnávacími operátory. Co například vrátí následující kód?

<?
$a
=5; $b=6;
echo
$a=$b;
?>

Vrátí šestku! Řádek s echo bychom totiž měli číst odzadu. Nejprve se do proměnné $a přiřadilo to, co bylo v proměnné $b. Celé přiřazení je ovšem v PHP bráno jako výraz, takže má hodnotu pravé strany. Proto příkaz echo (který se provede až po přiřazení) vrátí hodnotu 6. Kdybychom chtěli proměnné porovnat, používá se na to operátor == (dvě rovnítka), jak je uvedeno níže:

<?
$a
=5; $b=6;
echo
$a==$b; //vrátí FALSE (nic nevypíše)
// ale hodnoty proměnných se nezměnily
echo $a,$b;
?>

V PHP se můžete setkat ještě s operátorem === (tři rovnítka). Ten porovnává nejen hodnotu proměnné, ale i její typ. Říká se mu operátor identity a platí, že operace porovnání identity vrátí TRUE tehdy, když jsou si porovnávané výrazy rovny jak do hodnoty, tak do typu. Kraťounký příkad:

<?
$muj_integer
=5;
$muj_float = 5.0;
echo
$muj_integer==$muj_float; //to je pravda
echo $muj_integer===$muj_float; //tohle pravda není
?>

Dodejme pro úplnost, že existuje i operátor pro neidentitu (!==), který vrátí FALSE i v případě, že hodnoty výrazů rovnají, když se zároveň jejich typy liší. Operace neidentity vrátí samozřejmě FALSE i v případě, kdy se liší jak typy porovnávaných proměnných, tak i jejich hodnoty.

Ternární operátor

Na tomto operátoru je zajímavé, že pracuje ne se dvěma, ale se třemi výrazy a od toho pochází i jeho název. Striktně řečeno patří k operátorům porovnání. Funguje tak, že vyhodnocuje jeden výraz. Když ten výraz platí, je výsledkem operace druhý výraz, když ne, výsledkem je třetí výraz. Podobá se to slovním vyjádřením typu: "Když bude na účtu víc než 10000 tak vyber 5000, ale jinak vyber jen 2000". V PHP bychom to zapsali takto (oba řádky fungují stejně, záleží ne Vašem vkusu):

<?
$vyber
= $stav_uctu>10000 ? 5000 : 2000; // nebo
$stav_uctu>10000 ? $vyber=5000 : $vyber=2000;
?>

Ternární operátor patří k těm prvkům jazyka PHP, které si buď oblíbíte nebo se jim budete vyhýbat, ale většinou budete mít na ně vyhraněný názor. Je pravda, že bez ternárního operátoru se můžete obejít; ale zápis s jeho použitím bývá kratší.

Priorita operátorů

Operátory v PHP mají svou prioritu, takže kód se vždy nevykonává tupě zleva doprava. Například kód

<?echo 2+3*4?>

vrátí matematicky správných 14 a nikoli 20, protože PHP ví, že násobení má přednost před sčítáním. Pokud budeme chtít vestavěnou prioritu vyhodnocování výrazu změnit, použijeme závorky jako v matematice. Závorky mohou být vnořené, v takovém případě se výraz vyhodnocuje od nejvnitřnějších závorek. K tomu zase kratičký kód:

<?echo ((2+3)*4)/8?>

Protože prioritu operátorů někteří nenosí v hlavě, není žádná ostuda "uzávorkovat" výraz i v případě, že by se stejně vyhodnocoval i se závorkami. Někdy to vede k tomu, že je kód čitelnější.

Poznámky k článku

  • Existují i operátory, které jsme neprobírali. V praxi se s nimi ale většinou nesetkáte.
  • Pozor na rozdíl mezi přiřazením a porovnáním. Není to totéž.
  • Ternární operátor vyhodnocuje vždy jen větev, kterou se vydá. To je rozdíl od např. ASP, kde se vyhodnocují obě větve. To může být důležité pro správu chyb - ASP selže, pokud je chyba ve větvi, kterou se nakonec nepůjde, PHP neselže.

Verze pro tisk

pridej.cz

 

DISKUZE

ternalni? 3.11.2005 12:58 gofry




Příspívat do diskuze mohou pouze registrovaní uživatelé.
> Vyhledávání software
> Vyhledávání článků

24.8.2016 6:44 /Ondřej Čečák
Poslední týden CFP LinuxDays 2016; pokud byste rádi přednášeli na LinuxDays 2016 8. a 9. října v Praze, můžete svůj příspěvek přihlásit, následovat bude veřejné hlasování.
Přidat komentář

9.8.2016 22:56 /Petr Ježek
Zařazení souborového systému reiser4 do jádra 4.7 znamená konečně konec patchování jádra jen kvůli možnosti použít reiser4.
Přidat komentář

12.7.2016 13:14 /František Kučera
Spolek OpenAlt zve na 130. distribuovaný sraz příznivců svobodného softwaru a otevřených technologií (hardware, 3D tisk, SDR, DIY, makers…), který se bude konat ve čtvrtek 21. července od 18:00 v Radegastovně Perón (Stroupežnického 20, Praha 5).
Přidat komentář

11.7.2016 16:53 /Redakce Linuxsoft.cz
Konference LinuxDays hledá přednášející. Přihlášky poběží do konce prázdnin, v září bude hlasování a program. Více na https://www.linuxdays.cz/2016/cfp/.
Přidat komentář

8.5.2016 17:19 /Redakce Linuxsoft.cz
PR: Dne 26.5.2016 proběhne v Praze konference Cloud computing v praxi. Tématy bude např. nejnovější trendy v oblasti cloudu a cloudových řešení, cloudové služby, infrastruktura cloudu, efektivní využití cloudu, možné nástrahy cloudů a jak se jim vyhnout
Přidat komentář

21.4.2016 8:01 /František Kučera
Spolek OpenAlt zve na 127. distribuovaný sraz příznivců svobodného softwaru a otevřených technologií (hardware, 3D tisk, SDR, DIY, makers…), který se bude konat ve čtvrtek 28. dubna od 18:00 v Radegastovně Perón (Stroupežnického 20, Praha 5).
Přidat komentář

2.3.2016 22:41 /Ondřej Čečák
Letošní ročník konference InstallFest již tento víkend!
Přidat komentář

14.2.2016 16:39 /Redakce Linuxsoft.cz
O víkendu 5. a 6. března 2016 proběhne na pražském Strahově 8. ročník tradiční konference InstallFest. Celkem za dva dny uvidíte ​30 přednášek​ a ​6 workshopů.
Přidat komentář

   Více ...   Přidat zprávičku

> Poslední diskuze

12.8.2016 11:51 / Josef Zapletal
Jak udělat HTML/Javascript swiping gallery do mobilu?

8.8.2016 14:58 / Adams
fairies for hire

28.7.2016 15:51 / pepan
Re: NetBeans vs Eclipse

10.6.2016 21:10 / pavel riha
FreeBSD 10.3 a virtualizace

8.6.2016 21:56 / Milan Gallas
Nevalidní prefix m

Více ...

ISSN 1801-3805 | Provozovatel: Pavel Kysilka, IČ: 72868490 (2003-2016) | mail at linuxsoft dot cz | Design: www.megadesign.cz | Textová verze