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í
×
dnes 05:55 | Komunita

Dries Buytaert, autor a vedoucí projektu Drupal a prezident Drupal Association, požádal soukromě před několika týdny Larryho Garfielda, jednoho z klíčových vývojářů Drupalu, aby projekt Drupal opustil. Larry Garfield minulý týden na svých stránkách napsal, že důvodem jsou jeho BDSM praktiky a rozpoutal tím bouřlivou diskusi. Na druhý den reagoval Dries Buytaert i Drupal Association. Pokračuje Larry Garfield [reddit].

Ladislav Hagara | Komentářů: 17
dnes 04:44 | Humor

Společnost SAS zveřejnila na svých stránkách studii s názvem Open Source vs Proprietary: What organisations need to know (pdf). Organizace by měly například vědět, že ideální je mix 40 % open source softwaru a 60 % proprietárního softwaru [Slashdot].

Ladislav Hagara | Komentářů: 5
včera 23:33 | Zajímavý software

Byl vydán ShellCheck ve verzi 0.4.6. Jedná se o nástroj pro statickou analýzu shellových skriptů. Shellové skripty lze analyzovat na webové stránce ShellChecku, v terminálu nebo přímo z textových editorů. Příklady kódů, na které analýza upozorňuje a doporučuje je přepsat. ShellCheck je naprogramován v programovacím jazyce Haskell. Zdrojové kódy jsou k dispozici na GitHubu pod licencí GPLv3.

Ladislav Hagara | Komentářů: 0
včera 23:33 | Pozvánky

Czech JBoss User Group zve na setkání JBUG v Brně, které se koná ve středu 5. dubna 2017 v prostorách Fakulty informatiky Masarykovy univerzity v místnosti A318 od 18:00. Přednáší Pavol Loffay na téma Distributed Tracing and OpenTracing in Microservice Architecture.

… více »
mjedlick | Komentářů: 0
včera 11:33 | Zajímavý článek

Národní centrum kybernetické bezpečnosti (NCKB) vypracovalo (pdf) 26 podrobných bezpečnostních doporučení pro síťové správce. Tato doporučení jsou nastavena tak, aby je bylo možné aplikovat v každé instituci. Jsou rozdělena na tři základní části: bezpečnost infrastruktury, bezpečnost stanic a serverů a bezpečnost uživatelů.

Ladislav Hagara | Komentářů: 14
včera 05:55 | Komunita

Prezident Nadace pro svobodný software (FSF) Richard M. Stallman vyhlásil na slavnostním ceremoniálu v rámci konference LibrePlanet 2017 vítěze Free Software Awards za rok 2016. Ocenění za společenský přínos získal SecureDrop (Wikipedie). Za rozvoj svobodného softwaru byl oceněn Alexandre Oliva (Wikipedie).

Ladislav Hagara | Komentářů: 0
včera 04:44 | Nová verze

Byla vydána verze 0.7.0 debugovacího nástroje cgdb. Mezi novinky patří například zvýrazňování syntaxe jazyka Rust. Podrobnosti v poznámkách o vydání.

Neel | Komentářů: 0
25.3. 22:00 | Komunita

Portál Stack Overflow po roce opět vyzpovídal své uživatele, jedná se především o vývojáře softwaru, a zveřejnil (podcast) detailní výsledky průzkumu. Průzkumu se letos zúčastnilo více než 64 tisíc vývojářů. Jejich nejmilovanější platformou je linuxový desktop. Ten je také druhou nejpoužívanější platformou vývojářů.

Ladislav Hagara | Komentářů: 7
24.3. 11:55 | Komunita

Vývojový tým OpenSSL ve spolupráci s iniciativou Core Infrastructure konsorcia Linux Foundation spustil proces přelicencování této kryptografické knihovny ze současné licence na licenci Apache Licence v 2.0 (ASLv2). Nová licence usnadní začleňování OpenSSL do dalších svobodných a open source projektů. Všichni dosavadní vývojáři OpenSSL (Authors) obdrží v následujících dnech email s prosbou o souhlas se změnou licence.

Ladislav Hagara | Komentářů: 32
24.3. 01:11 | Komunita

Před třemi týdny Mozilla.cz představila projekt Photon, jehož cílem je návrh a implementace nového vzhledu Firefoxu. Včera zveřejnila první náhled vzhledu Photon. Práce na projektu Photon jsou rozděleny do pěti týmů, které celkem čítají 19 lidí. Zaměřují se na zlepšení prvního spuštění Firefoxu a zaujetí nových uživatelů, celkovou úpravu vzhledu, zlepšení animací, zrychlení odezvy uživatelského rozhraní a také upravení nabídek. Vývoj lze sledovat v Bugzille.

Ladislav Hagara | Komentářů: 50
Jak se stavíte k trendu ztenčování přenosných zařízení (smartphony, notebooky)?
 (14%)
 (2%)
 (71%)
 (3%)
 (10%)
Celkem 949 hlasů
 Komentářů: 72, poslední 1.3. 11:16
    Rozcestník

    Dotaz: jazyk c, argv na unsigned int

    16.4.2011 14:54 Tomasko | skóre: 4
    jazyk c, argv na unsigned int
    Přečteno: 708×
    Ahoj. Začínám tak prosím laické vysvětlování, děkuji. Potřebuji jeden parametr argv[1] převést na unsigned int a ještě zamezit, aby se v parametru nevyskytovaly písmena atd. Jen číslo od 0 do UINT_MAX.
    char *end; //pouzito pro kontrolu konverze
    unsigned int pocet_zidli= strtoul(argv[1], &end, 0);
    	if (*end != '\0')
    	{//osetreni vstupu argv[1]
    		fprintf(stderr, "%s\n", chybove_zpravy[CHYBA_ARGV1]);
    		return -1;
    	}
    
    zkoušel jsem to takhle. strtoul ale převádí string na unsigned long a já to uložím do unsigned int, je to problém? A pak ještě mi to hází když zadám např -1, nějaké hodně velké číslo, jak to prosím ošetřím děkuji.

    Odpovědi

    16.4.2011 20:48 Jirka P
    Rozbalit Rozbalit vše Re: jazyk c, argv na unsigned int
    Asi nejjednodušší je napsat si ten převod string -> int sám, není to nic těžkého. Budete tak mít plnou kontrolu nad tím, co to dělá. Takhle máte kromě záporných čísel neošetřené vstupy typu "010" (záleží, co s tím chcete).

    Ukládání do unsigned int není problém, dokud se ta hodnota do typu unsigned int vejde :)
    stativ avatar 16.4.2011 21:02 stativ | skóre: 54 | blog: SlaNé roury
    Rozbalit Rozbalit vše Re: jazyk c, argv na unsigned int
    No, při použití strtoul() musíš zkontrolovat ještě hodnotu errno. To je právě ten případ kdy ti to vrátí velké číslo (konkrétně ULONG_MAX), protože jsi mimo rozsah unsigned long.

    To, že to ukládáš do int může a nemusí být problém. Záleží na tom, jestli se může stát, že uživatel zadá číslo větší než je rozsah int. Pro ten případ by možná nebylo od věci před konverzí zkontrolovat, zda se vstup vleze do rozsahu int.

    Pak máš ještě možnost použít sscanf().
    Ať sežeru elfa i s chlupama!!! ljirkovsky.wordpress.com stativ.tk
    16.4.2011 23:54 Jirka P
    Rozbalit Rozbalit vše Re: jazyk c, argv na unsigned int
    Ono strtoul("-1", 0, 0) sice vrátí ULONG_MAX, ale errno nenastaví, protože k přetečení nedojde. Ono je to v té manuálovce trochu jinak...
    stativ avatar 17.4.2011 08:58 stativ | skóre: 54 | blog: SlaNé roury
    Rozbalit Rozbalit vše Re: jazyk c, argv na unsigned int
    No, k přetečení dojde, akorát ho strtoul zřejmě není schopno detekovat. V tom případě by bylo lepší použít strtol() a kontrolovat záporné hodnoty ručně.
    Ať sežeru elfa i s chlupama!!! ljirkovsky.wordpress.com stativ.tk
    stativ avatar 17.4.2011 08:59 stativ | skóre: 54 | blog: SlaNé roury
    Rozbalit Rozbalit vše Re: jazyk c, argv na unsigned int
    Tak koukám, že jsi mě se strtol() předběhl.
    Ať sežeru elfa i s chlupama!!! ljirkovsky.wordpress.com stativ.tk
    16.4.2011 22:56 Tomasko | skóre: 4
    Rozbalit Rozbalit vše Re: jazyk c, argv na unsigned int
    napsal jsem to takhle:
            char *end;
            int pocet_zidli= strtoul(argv[1], &end, 0);
    	if (errno == ERANGE || *end != '\0' || pocet_zidli < 0)
    	{//osetreni vstupu argv[1]
    		fprintf(stderr, "%s\n", chybove_zpravy[CHYBA_ARGV]);
    		return -1;
    	}
    
    btw nejsou nekde man. stranky v CZ, angličtinu neovladam a resim skolni projekt s procesy a vubec nevim kde hledat info :/ jak zacit. Pritom pri prihlasovani na Bc. nikde nebylo psano, ze vsechno bude v AJ, kdyz se anglictina vyucuje az na Bc. To uz je jina kapitola..
    17.4.2011 00:05 Jirka P
    Rozbalit Rozbalit vše Re: jazyk c, argv na unsigned int
    1) To není dobrý nápad. Konverze unsigned int -> int je nedefinovaná pro (unsigned)-1. Když už jdete do znaménkových typů, použijte strtol.

    2) Chybu (téměř) vždy indikuje návratová hodnota funkce, ne errno, to pouze označuje, ke které konkrétní chybě došlo. Kdyžtak to errno aspoň vynulujte na začátku, aby tam nezůstávaly staré zbytky.

    3) Manuálovky v češtině asi těžko, ale existují knihy (i české) o C, kde je to popsané. Poptejte se v knihovně.
    17.4.2011 16:05 Sten
    Rozbalit Rozbalit vše Re: jazyk c, argv na unsigned int
    strtoul převádí na unsigned long, nikoliv unsigned int. Pokud to rovnou převedete na unsigned int, nemáte šanci detekovat přetečení mezi UINT_MAX a ULONG_MAX. Takže lépe si takto nadefinujte strtoui:
    int strtoui(const char *str, char **end, int base)
    {
        unsigned long l = strtoul(str, end, base);
        if (l > UINT_MAX) {
            errno = ERANGE;
            return UINT_MAX;
        }
        return l;
    }
    
    A nezapomeňte na to, že strtoul nemaže errno, pokud nedošlo k chybě, takže si jej před jejím voláním vymažte, tedy volání by mělo vypadat nějak takto:
    char *end;
    errno = 0;
    unsigned int pocet_zidli = strtoui(argv[1], &end, 0);
    if (errno == ERANGE || *end != 0) {
        // Chyba
    }
    
    21.4.2011 10:31 Tomasko | skóre: 4
    Rozbalit Rozbalit vše Re: jazyk c, argv na unsigned int
    Děkuji Vám. Ale chci se zeptat, stejně když dám na vstup -100, tak to vypíše 4294967295. Mělo by to vyhodit chybu.
    21.4.2011 11:55 Sten
    Rozbalit Rozbalit vše Re: jazyk c, argv na unsigned int
    man strtoul:
    Negative values are considered valid input and are silently converted to the equivalent unsigned long int value.
    Takže řešení je použít strtol (strtoll pokud chcete celý rozsah unsigned long) a ošetřit obě meze.

    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.