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 10:44 | Komunita

Společně s openSUSE Conference 2018 probíhá dnes v Praze na Fakultě informačních technologií ČVUT jednodenní seminář CryptoFest 2018 (Twitter). Přednášky lze sledovat online na YouTube nebo na CCC.

Ladislav Hagara | Komentářů: 1
včera 02:22 | Komunita

Barton George, zakladatel a vedoucí projektu Sputnik, představil na svém blogu čtyři nové mobilní pracovní stanice Dell Precision s předinstalovaným Ubuntu. Jedná se o modely 3530, 5530, 7530 a 7730. Mobilní pracovní stanice budou certifikovány pro RHEL 7.5.

Ladislav Hagara | Komentářů: 9
včera 01:11 | Nová verze

Vyšla verze 5.12 prohlížeče map a GPS logů GPXSee. Nová verze přidává podporu Garmin JNX map a přináší mírné zlepšení výkonu/UX.

Martin Tůma | Komentářů: 0
25.5. 12:11 | Komunita

V Praze na Fakultě informačních technologií ČVUT probíhá openSUSE Conference 2018. Přednášky lze sledovat také online. Aktuální dění lze sledovat na Twitteru. Stisknutím zeleného tlačítka bylo dnes dopoledne vydáno openSUSE Leap 15.0.

Ladislav Hagara | Komentářů: 9
25.5. 11:44 | Komunita

Na Steamu probíhá do 28. května akce s názvem Spring Cleaning (Jarní úklid). V rámci akce lze hrát hry Don't Starve Together, Cities: Skylines, Tyranny, Borderlands 2, Middle-earth: Shadow of Mordor a Left 4 Dead 2 běžící na Linuxu zdarma [GamingOnLinux].

Ladislav Hagara | Komentářů: 2
24.5. 23:23 | Humor

Nová služba České pošty nazvaná Bezpečné úložiště nabízí až 100GB kapacitu pro "bezpečnou správu Vašich dat pod patronací důvěryhodného partnera Česká pošta".

… více »
Lol Phirae | Komentářů: 56
24.5. 22:14 | Bezpečnostní upozornění

Nova kritická hrozba VPNfilter bola zistená po dlhšiej spolupráce Talos s verejnými i súkromnými bezpečnostnými agentúrami. VPNfilter ohrozuje približne 500 000 zariadení v približne 54 krajinach. Zasiahnutí výrobcovia sú Linksys, MikroTik, NETGEAR, TP-Link (SOHO), QNAP (NAS). Správanie malwaru je nebezpečnej povahy, čo môže v určitých prípadoch spôsobiť škody veľkého rozsahu. Často tieto zariadenia sú na perimetri sieťe bez ochrany.

ewew | Komentářů: 5
24.5. 21:55 | Pozvánky

CSNOG (Czech and Slovak Network Operators Group), první československé setkání síťových operátorů, se uskuteční 11. a 12. června v Brně. Akce je určena poskytovatelům internetového připojení, síťovým operátorům, provozovatelům registrů, internetovým odborníkům a všem zájemcům o internetové a síťové technologie. Program je zaměřený na odborná, technická témata jako například síťová architektura, bezpečnost sítí, zpracování dat, DNS a další. Nutná je registrace.

Ladislav Hagara | Komentářů: 0
24.5. 21:33 | Komunita

Na Humble Bundle lze získat počítačovou hru, simulátor hackování, Hacknet (Wikipedie, YouTube) běžící také v Linuxu zdarma. Tentokrát je ke stažení také verze bez DRM a navíc soundtrack. Speciální akce končí v sobotu v 19:00.

Ladislav Hagara | Komentářů: 0
23.5. 20:11 | Zajímavý software

Alexandre Julliard oznámil jménem vývojového týmu Wine vydání první verze 1.0 knihovny vkd3d určené pro překlad volání Direct3D 12 na Vulkan. Zdrojové kódy vkd3d jsou k dispozici pod licencí LGPLv2.1+.

Ladislav Hagara | Komentářů: 1
Používáte pro některé služby inetd?
 (35%)
 (23%)
 (42%)
Celkem 156 hlasů
 Komentářů: 5, poslední 22.5. 16:46
    Rozcestník

    Dotaz: scanf a C

    20.5.2005 09:34 ssil | skóre: 15
    scanf a C
    Přečteno: 171×
    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.