|
|||||||||||||||||||||||||||||||||||||||||||||||
Menu
Distributions (131)
bootable [55]
commercial [7] no-commercial [42] unclassified [20] [7]
Software (10844)
|
C/C++ (7) - PodmínkaDnes se naučíme pracovat s logickými hodnotami. Dojde i na jejich využití: podmínku a podmíněný výraz.
PorovnáníPro logické hodnoty ano/ne není v C zvláštní typ. Místo něj se používá se int, nula znamená ne a jakákoli jiná hodnota ano. Jako ano se v praxi nejčastěji používá jednička, ale stejně dobře poslouží třeba minus sto dvacet pět. Typ int chápaný jako logická hodnota vracejí porovnávací operátory <, <=, ==, >= a > s významem menší, menší nebo rovno, rovná se, větší nebo rovno a větší. Všimněte si, že rovnost se testuje operátorem == a nikoli prostým =, které je rezervováno pro přiřazení. Dělá to problémy mnoha začínajícím céčkařům zvyklým na jiný jazyk. Porovnávat můžeme celá i reálná čísla. Při práci s reálnými čísly se musíme smířit se zaokrouhlovací chybou a nepřesností některých aritmetických operátorů. Zejména test na rovnost nemusí dopadnout podle představ programátora, pokud porovnává čísla jako 1.0000000298023 a 0.99999997542, i když třeba vznikla výpočtem, který by v ideálním světě matematiky vedl přesně k 1.0. Logické operátoryÚlohu logických spojek mají v C operátory !, && a ||. Vykřičník je negace (not/ne), && má význam konjunkce (and/a) a || je alternativa (or/nebo). Logické xor C nemá, nicméně je možné vyxorovat dvě čísla bit po bitu, ukážeme si to v některém z dalších dílů. Nejvyšší prioritu má negace, potom konjunkce a nakonec alternativa. muze_ridit = !pil && ma_ridicak || ma_poslaneckou_imunitu; Operátory && a || zaručují pořadí vyhodnocování. Nejprve se vyhodnotí levý operand a vyhodnocení pravého následuje pouze pokud je to nezbytné pro vypočtení hodnoty výrazu. V našem případě by tak u abstinenta s řidičákem již nedošlo na test imunity. Je proto zcela korektní psát kód jako muzeme_lyzovat = lyzaru > 0 && hulek / lyzaru >= 2; /* neboli muzeme_lyzovat = ((lyzaru > 0) && ((hulek / lyzaru) >= 2))); */ V jazykách s úplným (nebo nespecifikovaným) vyhodnocováním výrazů by nám mohl obdobný příklad spadnout na dělení nulou, pokud je lyzaru nula, ale v Céčku vše projde. Podmíněný příkazPřirozeným využitím logických hodnot je podmíněný příkaz. unsigned synacku = 5, jablicek = 11; if (synacku > 0) printf("Každý synáček dostane %u jablíček " "a %u jich zbude na tatínka.\n", jablicek / synacku, jablicek % synacku); else { puts("Tatínek má 0 synů."); puts("Raději nebudeme dělit nulou."); } Podmínka má syntaxi if (výraz) příkaz1 nebo blok1 [ else příkaz2 nebo blok2 ] Nejprve se vyhodnotí podmínka, je-li splněna vykoná se příkaz1/blok1, v opačném případě se přeskočí a pokud následuje nepovinná větev else vykoná se příkaz2/blok2. Podmínit lze jen jeden příkaz, pokud chceme podmíněně vykonat příkazů více, je třeba je pomocí složených závorek seskupit do bloku, jako v případě else větve z příkladu se synáčky a jablíčky. Po vykonání podmínky (ať už byla splněna nebo ne) program pokračuje následujícím příkazem. Podmínky lze podobně jako jiné konstrukce v C do sebe zanořovat. if (hotovost > cena) if (ucet > cena) puts("Můžeš platit kartou i hotovostí."); else puts("Zaplať hotovostí."); else if (ucet > cena) puts("Zaplať kartou."); else puts("Ten nový počítač nepotřebuješ."); Nejasnost by mohla vzniknout v případě if (výraz1) if (výraz2) příkaz1 else příkaz2 příkaz3 nebo konec bloku Není totiž jasné ke které podmínce se váže else větev. Norma C to vyřešila jednoznačně, v podobných případech else větev patří ke vnitřní podmínce, vykoná se tedy pokud výraz1 && !výraz2, ovšem z důvodu čitelnosti programu je lepší celou vnitřní podmínku od druhého if až po příkaz2 uzavřít pomocí složených závorek do bloku. Podmíněný výrazKromě klíčového slova if a podmíněného příkazu, nabízí C i ternární operátor ?: - podmíněný výraz. a ? b : c Nejprve se vyhodnotí logická hodnota a. Je-li splněna, je výsledkem výrazu b, v opačném případu c. V čistém C (narozdíl od C++) nikdy není výsledkem podmíněného výrazu l-hodnota. Není tedy možné mít podmíněný výraz na levé straně přiřazení a podmínku použít na určení proměnné, do které se má přiřadit. Ačkoli některé překladače toto omezení nemají, není dobré toho využívat. /* Tohle v C nemusí projít */ (c > 0 ? a : b) = c; Podmíněný výraz naopak můžeme s úspěchem použít na ošetření dělení nulou. vysledek = i ? 128 / i : 0; Někteří programátoři se podmíněnému výrazu systematicky vyhýbají a rozepisují jej pomocí if a else. Pokračování příštěV dalším dílu probereme cykly.
Related article
C/C++ (1) - Úvod C/C++ (2) - První program C/C++ (3) - Proměnné a konstanty C/C++ (4) - Funkce printf C/C++ (5) - Funkce printf podruhé C/C++ (6) - Operátory C/C++ (8) - Cykly C/C++ (9) - Pole C/C++ (10) - Standardní vstup a výstup C/C++ (11) - Čtení a konverze čísel C/C++ (12) - Preprocesor C/C++ (13) - Preprocesor podruhé C/C++ (14) - Funkce C/C++ (15) - Proměnné C/C++ (16) - Hlavičkové soubory C/C++ (17) - Makefile C/C++ (18) - Makefile podruhé C/C++ (19) - Příkaz switch a bitové operátory C/C++ (20) - Alokace paměti C/C++ (21) - Práce s řetězci C/C++ (22) - Struktury C/C++ (23) - Seznam C/C++ (24) - Soubory C/C++ (25) - Funkce s proměnným počtem parametrů C/C++ (26) - Standardní knihovna C/C++ (27) - Standardní knihovna podruhé C/C++ (28) - Standardní knihovna potřetí C/C++ (29) - Standardní knihovna počtvrté C/C++ (30) - Výčtový typ a nestandardní knihovny C/C++ (31) - Jazyk C++, historie, charakteristika, vztah k C C/C++ (32) - Omezení C++ oproti C C/C++ (33) - Rozdíly mezi C a C++ C/C++ (34) - Drobná vylepšení C++ C/C++ (35) - Reference, funkce C/C++ (36) - Prostory jmen C/C++ (37) - Prostory jmen podruhé C/C++ (38) - Prostory jmen potřetí C/C++ (39) - Objektově orientované programování C/C++ (40) - Dědičnost a virtuální metody GCC vs. CLANG C++ Binární vyhledávací stromy C++ Datová struktura zásobník C++ - Hashování C++ - Vyhledávání v textu - Brute Force algoritmus C++ šablony Grafy a grafové algoritmy I Grafy a grafové algoritmy II C++ výjimky C++ Funktory neboli funkční objekty Grafy a grafové algoritmy III. C++ a garbage collector Previous Show category (serial) Next
|
Szukanie oprogramowania
|
|||||||||||||||||||||||||||||||||||||||||||||
©Pavel Kysilka - 2003-2024 | maillinuxsoft.cz | Design: www.megadesign.cz |