Programování v jazyce C - formátované čtení dat, funkce scanf
 x   TIP: Přetáhni ikonu na hlavní panel pro připnutí webu
Reklama

Programování v jazyce C - formátované čtení dat, funkce scanfProgramování v jazyce C - formátované čtení dat, funkce scanf

 

Programování v jazyce C - formátované čtení dat, funkce scanf

Google       Google       18. 8. 2006       50 479×

V tomto díle se podíváme na funkci scanf a některé další možnosti načítání dat

Reklama
Reklama

Funkce scanf

Funkce scanf slouží k načítání dat ze standardního vstupu a tyto data ukládá do proměnných které jí předáme jako paramtery s jednou "zvláštností". To si ale vyjasníme o několik řádků níže na praktické ukázce. Funcke scanf má následující syntaxi

int scanf("formát vstupního retezce", seznam promennych);

funkce scanf pracuje tak že načte najednou celou sekvenci danou formátovacím řetězcem který je stejný jako u funkce printf. Jedinou odlišností, kterou zde najdeme, je ta, že u proměnných, do kterých chceme data načítat, musíme použít refenční operátor & ampersand. Ukážeme si to na úříkladu.

Scanf("%lf %lf", &a, &b);

Tento refenční operátor slouží k tomu že se na proměnnou odvoláváme odkazem. To znamená, že takto předáme funkci scanf adresu v paměti, kam má načtenou hodnotu zapsat. K lepšímu pochopení uvedu příklad

int a = 10;
printf("promenna a ma hodnotu %d a lezi na adrese %x\n", a, &a);

Zde předáváme funkci pro výpis dvakrát proměnnou a, ale po druhé používáme referenční operátor, což má za následek, že funkci printf je předána adresa proměnné a, která ji vytiskne v hexadecimálním tvaru. Z toho vyplývá, že použitím referenčního operátoru se odkazujeme na místo v operační paměti, kam se mají data zapsat.

Funkce scanf je velice vhodná, pokud potřebujeme zpracovávat data v nějakém speciálním formátu. Toho budeme využívat později pomocí příbuzné funkce fscanf, která slouží pro čtení ze souboru, ale o tom až později. U funkce scanf si ukážeme ještě jeden příklad, který nám zmíněné chování blíže objasní.

double x, y ;
    printf("Zadejte hodnoty pro a a b\n");
    scanf("x=%lf y=%lf", &x, &y);
    printf("Nacetl jsem %lf, %lf\n", x, y);   

Pokud nyní zadáme na vstup pouze čísla, funkce scanf se čtením neuspěje, protože data očekávala v jiném formátu. Pokud ale zadáme

a = 10.5
b = 100

vše již proběhne v pořádku.

Funkce getcahr / putchar

Tyto dvě funkce představují základní možnost načítání a vypisování znaků. První funkce getchar má následující syntaxi.

int getchar(void);

Funkce nepřebírá žádné parametry, pouze vrací celé celé číslo, co by ASCII kód načteného znaku. Tím se dostáváme k důležité informaci, a tou je ta, že jazyk C vnitřně pracuje se znakovou proměnnou, jako s celým číslem. Druhá funkce putchar

void putchar(int ch);

slouží k výpisu znaku na standardní výstup a přebírá jediný parametr, a tím je celé číslo reprezentující kód znaku který chceme tisknout. Nakonec ukázka, jak pomocí getchar znak načíst, a pomocí putchar zase zpět vypsat.


int ch;
printf("Zadejte alfanumericky znak:");
ch = getchar();
printf("Vytiskneme pomoci putchar:");
putchar(ch);

×Odeslání článku na tvůj Kindle

Zadej svůj Kindle e-mail a my ti pošleme článek na tvůj Kindle.
Musíš mít povolený příjem obsahu do svého Kindle z naší e-mailové adresy kindle@programujte.com.

E-mailová adresa (např. novak@kindle.com):

TIP: Pokud chceš dostávat naše články každé ráno do svého Kindle, koukni do sekce Články do Kindle.

Hlasování bylo ukončeno    
0 hlasů
Google
Autor se věnuje programování v jazycích C/C++, GTK+ a Zajímá se o GNU/Linux. Mezi další zájmy patří scifi a četba.

Nové články

Obrázek ke článku Blockchain & Bitcoin konference

Blockchain & Bitcoin konference

V pátek 19. 5. 2017 se v pražském konferenčním centru Andel’s konala Blockchain & Bitcoin konference. Řada odborníků a podnikatelů v oboru blockchainu a kryptoměn představila možnosti budoucího směřování tohoto oboru. Speakeři většinou rusky mluvící provenience prezentovali řešení svých firem založená na technologii blockchainu.

Reklama
Reklama
Obrázek ke článku Malware KONNI se úspěšně skrýval 3 roky. Odhalil ho bezpečnostní tým Cisco Talos

Malware KONNI se úspěšně skrýval 3 roky. Odhalil ho bezpečnostní tým Cisco Talos

Bezpečnostní tým Cisco Talos odhalil celkem 4 kampaně dosud neobjeveného malwaru, který dostal jméno KONNI. Ten se dokázal úspěšně maskovat od roku 2014. Zpočátku se malware zaměřoval pouze na krádeže citlivých dat. Za 3 roky se ale několikrát vyvinul, přičemž jeho současná verze umožňuje útočníkovi z infikovaného počítače nejenom krást data, ale i mapovat stisky na klávesnici, pořizovat screenshoty obrazovky či v zařízení spustit libovolný kód. Pro odvedení pozornosti oběti zasílali útočníci v příloze také obrázek, zprávu a výhružkách severokorejského režimu či kontakty na členy mezinárodních organizací.

Obrázek ke článku Pouze jedna z deseti lokálních firem ví o pokutách plynoucích z GDPR

Pouze jedna z deseti lokálních firem ví o pokutách plynoucích z GDPR

Trend Micro, celosvětový lídr v oblasti bezpečnostních řešení a VMware, přední světový dodavatel cloudové infrastruktury a řešení pro podnikovou mobilitu, oznámily výsledky výzkumu mezi českými a slovenskými manažery zodpovědnými za ochranu osobních údajů, který zjišťoval, jak jsou připraveni na nové nařízení o ochraně osobních údajů (GDPR). Většina firem v České republice a na Slovensku nad 100 zaměstnanců je již s novým nařízením GDPR obeznámena. Výzkum provedený ve spolupráci s agenturou Ipsos ukázal, že téměř 8 firem z 10 o nařízení ví, přičemž jeho znalost je o něco vyšší na Slovensku (89 %) než v České republice (69 %).

Obrázek ke článku Vyděračský software Locky se vrací, tváří se jako potvrzení platby, odhalil tým Cisco Talos

Vyděračský software Locky se vrací, tváří se jako potvrzení platby, odhalil tým Cisco Talos

Jeden z nejznámějších ransomwarů, Locky, se vrací. Po většinu roku 2016 patřil mezi nejrozšířenější vyděračské softwary. Ke svému šíření využíval emailové kampaně s infikovanými přílohami. Ransomware Locky byl rozesílán prostřednictvím botnetu (internetový robot zasílající spamy) Necurs. Jeho aktivita na konci roku 2016 téměř upadla a spolu s ní i šíření ransomwaru Locky. Před několika týdny se Necurs opět probudil a začal posílat spamy nabízející výhodný nákup akcií. Dne 21. dubna zaznamenal bezpečnostní tým Cisco Talos první velkou kampaň ransomwaru Locky prostřednictvím botnetu Necurs za posledních několik měsíců.

loadingtransparent (function() { var po = document.createElement('script'); po.type = 'text/javascript'; po.async = true; po.src = 'https://apis.google.com/js/plusone.js'; var s = document.getElementsByTagName('script')[0]; s.parentNode.insertBefore(po, s); })();
Hostujeme u Českého hostingu       ISSN 1801-1586       ⇡ Nahoru Webtea.cz logo © 20032017 Programujte.com
Zasadilo a pěstuje Webtea.cz, šéfredaktor Lukáš Churý