ARCHIV |
|||||||||||||||||||||||||||||||||||||||||||||||||||
Software (10844)
Distribuce (131)
Skripty (697)
Menu
Diskuze
Informace
|
C/C++ (3) - Proměnné a konstantyDnes se podíváme na zápis proměnných a konstant, dojde i na escape sekvence. Definice proměnnýchV minulém dílu jsme probrali základní číselné typy. Abychom je mohli využít, musíme definovat proměnnou. Ukážeme si to v následujícím příkladu. /* globální proměnné typu double */ double d1, d2; int main(void) { /* lokální proměnné typu int*/ int j; int i = 0; d1 = 1.5; j = i; return j; } Definice může být globální, nebo lokální. Globálně (mimo funkci) jsou definované dvě proměnné typu double, jmenují se d1 a d2. Využít je můžu všude, kde o nich překladač ví, což v našem případě znamená od definice dál. Lokální i a j jsou platné pouze ve funkci main. V C lze lokální proměnné definovat pouze na začátku bloku, není tedy možné nejprve provést příkazy jako například přiřazení nebo volání jiné funkce, a teprve potom definovat proměnnou. Blok je kód mezi párem složených závorek, v našem případě celé tělo funkce. Pokud jsou definovány lokální a globální proměnné stejného jména, lokální identifikátor překryje globální, ale v praxi by k tomu nemělo docházet, neboť rozumný programátor se této situaci raději vyhne. Všimněte si, že se nejdřív píše typ, a teprve potom název proměnné. Céčko (podobně jako Unix) rozlišuje malá a velká písmena, a to jak u klíčových slov, tak i u identifikátorů. Nelze tedy psát INT místo int, Return místo return a podobně. Všechna klíčová slova a názvy funkcí ze standardní knihovny se píší malými písmeny. Uživatelské identifikátory toto omezení nemají, můžeme tedy klidně definovat proměnné s velkými písmeny v názvu. Lze dokonce vytvořit proměnné, které se liší pouze velikostí písmen, například Soucet a soucet, ale pochopitelně tím utrpí přhlednost programu. Identifikátor může obsahovat malá a velká písmena anglické abecedy, podtržítko a také číslice, nesmí ovšem číslicí začínat. Do proměnné lze přiřadit hodnotu rovnítkem, a to buď přímo v definici, nebo v příkazu. První případ se nazývá inicializace a v našem příkladu jsme takhle nastavili proměnnou i. Druhý případ se týká proměnných d1 a j. Je dobré si uvědomit, že znak = znamená přiřazení, nikoli porovnání. KonstantyCelá číslaCeločíselné konstanty lze zapsat ve třech soustavách.
V šestnáctkové soustavě nezáleží na velikosti písmen. Trochu nešťastná je volba úvodní nuly u osmičkové soustavy, kvůli tomu například nelze desítková čísla zarovnávat zleva nulami na jednotnou velikost. Nelze psát čísla ve dvojkové soustavě, což by se někdy hodilo. Typ konstanty se určí implicitně (obvykle to bude int) nebo lze vynutit unsigned a long příponou U, u a L, l. Můžeme tak psát 65567L, 2145644u a podobně, ale není to příliš časté. Reálná číslaReálné konstanty se píší v desítkové soustavě a buď s desetinou tečkou (2.4, 0.145, .24, 87.), nebo v exponenciální formě (4e2, 45E-5). Typ lze vynutit float nebo long double příponou F, f nebo L, l. ZnakyZnaky lze psát pomocí apostrofů, například 'a', 'B', 'č', tří osmičkových číslic, například '\001', '\077', '\644' (což v případě jednotlivého znaku nemá příliš význam, můžu rovnou použít příslušné číslo reprezentující daný znak, tj. obvykle ASCII hodnotu) nebo escape sekvencev v apostrofech.
Znak uvozovky lze zapsat prostě takhle '"', není tedy třeba escapovat. ŘetězceS řetězcovou konstantou jako parametrem funkce puts jsme se již setkali v minulém dílu. Píší se do uvozovek a lze v nich použít i stejné sekvence jako v případě jednotlivých znaků. Rozdíl je jen v tom, že místo znaku apostrofu se musí zaescapovat uvozovka.
Prvních pět příkladů z tabulky jsem již vysvětlil, v předposledním dokumentuji docela příjemnou vlastnost Céčka. Několik po sobě jdoucích řetězcových konstant je chápáno jako jeden řetězec vzniklý jejich složením, typické využití může vypadat třeba takhle: puts( "V programu došlo k chybě.\n" "Ozvěte se autorovi na adresu autor@program.cz\n" "Děkuji." ); return 1; Toto jednoduché skládání řetězců se dá uplatnit pouze na konstanty. Nejdůležitější je poslední příklad. Řetězec v C je ve skutečnosti ukazatel do paměti. Při zápisu řetězcové konstanty se vyhradí kus paměti (alespoň) o jeden byte větší než délka řetězce, který se do ni zkopíruje. Jednomu znaku odpovídá jeden byte paměti. Za vlastní text se uloží nula, která řetězec ukončuje. Pokud pak konstantu použiju (třeba jako parametr funkce puts), jde ve skutečnosti o ukazatel na začátek vyhrazeného kusu paměti. V posledním příkladu jsem vložil nulu přímo do řetězce. To mi Céčko umožní, ale pokud jej použiju v jakékoli standardní funkci, interpretovat se bude pouze text až po nejbližší nulu, která bude (mylně) pokládána za ukončovací. Příklad přesto má smysl, existují totiž knihovny s funkcemi, které jako parametr požadují nebo alespoň akceptují řetězec s nulovým znakem, délka se pak musí zadat nějak jinak, typicky jako další parametr. Ve standardní knihovně se s žádnou takovou funkcí nesetkáte. Pokračování příštěV dalším díle se podíváme na nejznámější C funkci printf.
Související články
Předchozí Celou kategorii (seriál) Další
C/C++ (1) - Úvod
C/C++ (2) - První program C/C++ (4) - Funkce printf C/C++ (5) - Funkce printf podruhé C/C++ (6) - Operátory C/C++ (7) - Podmínka 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 Předchozí Celou kategorii (seriál) Další
|
Vyhledávání software
Vyhledávání článků
28.11.2018 23:56 /František Kučera 12.11.2018 21:28 /Redakce Linuxsoft.cz 6.11.2018 2:04 /František Kučera 4.10.2018 21:30 /Ondřej Čečák 18.9.2018 23:30 /František Kučera 9.9.2018 14:15 /Redakce Linuxsoft.cz 12.8.2018 16:58 /František Kučera 16.7.2018 1:05 /František Kučera
Poslední diskuze
31.7.2023 14:13 /
Linda Graham 30.11.2022 9:32 /
Kyle McDermott 13.12.2018 10:57 /
Jan Mareš 2.12.2018 23:56 /
František Kučera 5.10.2018 17:12 /
Jakub Kuljovsky | |||||||||||||||||||||||||||||||||||||||||||||||||
ISSN 1801-3805 | Provozovatel: Pavel Kysilka, IČ: 72868490 (2003-2024) | mail at linuxsoft dot cz | Design: www.megadesign.cz | Textová verze |