abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    včera 14:00 | Zajímavý článek

    Byl publikován aktuální přehled vývoje renderovacího jádra webového prohlížeče Servo (Wikipedie).

    Ladislav Hagara | Komentářů: 0
    včera 12:00 | Nová verze

    V programovacím jazyce Go naprogramovaná webová aplikace pro spolupráci na zdrojových kódech pomocí gitu Forgejo byla vydána ve verzi 12.0 (Mastodon). Forgejo je fork Gitei.

    Ladislav Hagara | Komentářů: 0
    17.7. 18:44 | Zajímavý článek

    Nová čísla časopisů od nakladatelství Raspberry Pi zdarma ke čtení: Raspberry Pi Official Magazine 155 (pdf) a Hello World 27 (pdf).

    Ladislav Hagara | Komentářů: 1
    17.7. 16:11 | Nová verze

    Hyprland, tj. kompozitor pro Wayland zaměřený na dláždění okny a zároveň grafické efekty, byl vydán ve verzi 0.50.0. Podrobný přehled novinek na GitHubu.

    Ladislav Hagara | Komentářů: 2
    17.7. 15:55 | Komunita

    Patrick Volkerding oznámil před dvaatřiceti lety vydání Slackware Linuxu 1.00. Slackware Linux byl tenkrát k dispozici na 3,5 palcových disketách. Základní systém byl na 13 disketách. Kdo chtěl grafiku, potřeboval dalších 11 disket. Slackware Linux 1.00 byl postaven na Linuxu .99pl11 Alpha, libc 4.4.1, g++ 2.4.5 a XFree86 1.3.

    Ladislav Hagara | Komentářů: 5
    16.7. 21:22 | IT novinky

    Ministerstvo pro místní rozvoj (MMR) jako první orgán státní správy v Česku spustilo takzvaný „bug bounty“ program pro odhalování bezpečnostních rizik a zranitelných míst ve svých informačních systémech. Za nalezení kritické zranitelnosti nabízí veřejnosti odměnu 1000 eur, v případě vysoké závažnosti je to 500 eur. Program se inspiruje přístupy běžnými v komerčním sektoru nebo ve veřejné sféře v zahraničí.

    Ladislav Hagara | Komentářů: 19
    16.7. 16:22 | IT novinky

    Vláda dne 16. července 2025 schválila návrh nového jednotného vizuálního stylu státní správy. Vytvořilo jej na základě veřejné soutěže studio Najbrt. Náklady na přípravu návrhu a metodiky činily tři miliony korun. Modernizovaný dvouocasý lev vychází z malého státního znaku. Vizuální styl doprovází originální písmo Czechia Sans.

    Ladislav Hagara | Komentářů: 26
    16.7. 15:33 | Upozornění

    Vyhledávač DuckDuckGo je podle webu DownDetector od 2:15 SELČ nedostupný. Opět fungovat začal na několik minut zhruba v 15:15. Další služby nesouvisející přímo s vyhledáváním, jako mapyAI asistent jsou dostupné. Pro některé dotazy během výpadku stále funguje zobrazování například textu z Wikipedie.

    bindiff | Komentářů: 8
    16.7. 13:33 | Bezpečnostní upozornění

    Více než 600 aplikací postavených na PHP frameworku Laravel je zranitelných vůči vzdálenému spuštění libovolného kódu. Útočníci mohou zneužít veřejně uniklé konfigurační klíče APP_KEY (např. z GitHubu). Z více než 260 000 APP_KEY získaných z GitHubu bylo ověřeno, že přes 600 aplikací je zranitelných. Zhruba 63 % úniků pochází z .env souborů, které často obsahují i další citlivé údaje (např. přístupové údaje k databázím nebo cloudovým službám).

    Ladislav Hagara | Komentářů: 5
    16.7. 00:11 | Nová verze

    Open source modální textový editor Helix, inspirovaný editory Vim, Neovim či Kakoune, byl vydán ve verzi 25.07. Přehled novinek se záznamy terminálových sezení v asciinema v oznámení na webu. Detailně v CHANGELOGu na GitHubu.

    Ladislav Hagara | Komentářů: 0
    Jaký je váš oblíbený skriptovací jazyk?
     (59%)
     (27%)
     (7%)
     (3%)
     (0%)
     (1%)
     (4%)
    Celkem 410 hlasů
     Komentářů: 16, poslední 8.6. 21:05
    Rozcestník

    Dotaz: scanf a C

    20.5.2005 09:34 ssil | skóre: 15
    scanf a C
    Přečteno: 216×
    Při načítání z klávesnice jsem narazil na to, že pokud nejdříve načítám znak a pak číslo (scanf ("%c", &zn) a později scanf ("%d", &i)) je to bez problémů, ale pokud nejdřív načtu číslo, znak se už nenačte. To je skutečnost s níž je třeba počítat, nebo dělám něco blbě.

    Odpovědi

    20.5.2005 09:48 unchallenger | skóre: 69 | blog: unchallenger
    Rozbalit Rozbalit vše Re: scanf a C
    Podle toho, co je to za znak. Pokud je to třeba číslice, vůbec bych se nedivil ;-)
    20.5.2005 09:58 unchallenger | skóre: 69 | blog: unchallenger
    Rozbalit Rozbalit vše Re: scanf a C
    Ale jinak děláš něco blbě. Spusť
    scanf("%d", &i);
    scanf("%c", &c);
    printf("[%d][%c]\n", i, c);
    
    a napiš 12345x. Vypíše to [12345][x].
    20.5.2005 10:33 ssil | skóre: 15
    Rozbalit Rozbalit vše Re: scanf a C
    Tak tohle funguje, ale už třeba 12345 x nefunguje. Přitom %c by mělo zaručit načtení i bílých znaků takže jsem očekával výpis [12345][ x]. Taky pokus, kdy jsem mezi scanf dal třeba tisk načtených čísel, byl neúspěšný.
    20.5.2005 10:36 0
    Rozbalit Rozbalit vše Re: scanf a C
    %c nacte jeden znak nasledujici za cislem(tedy ve tvem pripade mezeru), zkus misto toho pouzit %*c%c, nebo %s do stringu.
    20.5.2005 11:17 ssil | skóre: 15
    Rozbalit Rozbalit vše Re: scanf a C
    S tím %*c%c mám zcela nesmyslné výsledky a s %s mi to hlásí neoprávněný přístup do paměti SIGSEGV. Nějaké nápady?
    20.5.2005 11:51 Michal Marek (twofish) | skóre: 55 | blog: { display: blog; } | Praha
    Rozbalit Rozbalit vše Re: scanf a C
    Naalokovat paměť pro ten řetězec :-) Jestli to chceš mít i s whitespace, tak mě napadá jedině
    int i; char space[81], word[81];
    
    space[sizeof(space)-1] = 0;
    word[sizeof(space)-1] = 0;
    scanf("%d%80[ \n\t]%80s", &i, space, word);
    printf("[%d][%s%s]\n", i, space, word);
    
    Nebo napiš co chceš... %c načte pevný počet znaků.
    20.5.2005 11:57 Michal Marek (twofish) | skóre: 55 | blog: { display: blog; } | Praha
    Rozbalit Rozbalit vše Re: scanf a C
    Blbnu, to nulování posledního bajtu tam není potřeba, to jsem zkoušel %c.
    20.5.2005 12:01 unchallenger | skóre: 69 | blog: unchallenger
    Rozbalit Rozbalit vše Re: scanf a C
    Nebo použít GNU libc a "%as", který alokuje dostatečně velký string sám...

    Ale stejně nechápu úvodní představu, že %c načte více než jeden znak.
    20.5.2005 11:57 unchallenger | skóre: 69 | blog: unchallenger
    Rozbalit Rozbalit vše Re: scanf a C
    The `%c' conversion is the simplest: it matches a fixed number of characters, always. The maximum field width says how many characters to read; if you don't specify the maximum, the default is 1. This conversion doesn't append a null character to the end of the text it reads. It also does not skip over initial whitespace characters.

    Takže žádné bílé znaky nenačítá. Použij "%1s", ten bílé znaky přeskakuje.

    Za zegfaulty a divné chování může to, že nečteš dokumentaci a nedáváš tomu správné argumenty.
    20.5.2005 11:58 unchallenger | skóre: 69 | blog: unchallenger
    Rozbalit Rozbalit vše Re: scanf a C
    s/nenačítá/nepřeskakuje/

    Načítá právě jakýkoli jeden znak, včetně bílého.
    20.5.2005 12:31 ssil | skóre: 15
    Rozbalit Rozbalit vše Re: scanf a C
    Tak jsem si ujasnil, že %c načítá jen jeden znak a že jde načíst číslo, načíst znak a pak to teprve vytisknout. Ale vrátím se k původní otázce. Načtu znak, vytisknu jej, načtu číslo, vytisknu jej. Ale načtu číslo, vytisknu jej, chci načíst znak, ale z následujícího tisku zjišťuju, že se nenačetl.
    20.5.2005 12:40 unchallenger | skóre: 69 | blog: unchallenger
    Rozbalit Rozbalit vše Re: scanf a C
    Ne.
    scanf("%d", &i);
    printf("[%d]\n", i);
    scanf("%c", &c);
    printf("[%c]\n", c);
    
    Funguje úplně stejně jako první příklad.

    Nejspíš opět načítáš jiný znak, než si myslíš, že načítáš.
    20.5.2005 16:53 ssil | skóre: 15
    Rozbalit Rozbalit vše Re: scanf a C
    Bohužel, u mě to nefunguje. Napíšu číslo, dám enter a ono to napíše to číslo do hranatých závorek a už to na nic nečeká, vypíše to ty další hranaté závorky a navíc každou na nový řádek. Výsledek pak vypadá takto:
    45
    [45]
    [
    ]
    20.5.2005 17:04 Michal Marek (twofish) | skóre: 55 | blog: { display: blog; } | Praha
    Rozbalit Rozbalit vše Re: scanf a C
    Ten enter je taky znak.

    Založit nové vláknoNahoru

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.