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

    V Bolzanu probíhá konference SFSCON (South Tyrol Free Software Conference). Jean-Baptiste Kempf, zakladatel a prezident VideoLAN a klíčový vývojář VLC media playeru, byl na ní oceněn cenou European SFS Award 2025 udělovanou Free Software Foundation Europe (FSFE) a Linux User Group Bolzano‑Bozen (LUGBZ).

    Ladislav Hagara | Komentářů: 0
    dnes 02:44 | Zajímavý projekt

    Open-source minimalistický trackball Ploopy Nano byl po modelech modelech Classic a Thumb Trackball také aktualizován. Nová verze Nano 2 používá optický senzor PAW3222 a k původně beztlačítkovému designu přidává jedno tlačítko, které ve výchozí konfiguraci firmwaru QMK přepíná režim posouvání koulí. Sestavený trackball nyní vyjde na 60 kanadských dolarů (bez dopravy a DPH).

    |🇵🇸 | Komentářů: 0
    včera 14:22 | Zajímavý článek

    Github publikoval Octoverse 2025 (YouTube), tj. každoroční přehled o stavu open source a veřejných softwarových projektů na GitHubu. Každou sekundu se připojil více než jeden nový vývojář. Nejpoužívanějším programovacím jazykem se stal TypeScript.

    Ladislav Hagara | Komentářů: 0
    včera 09:55 | Komunita

    Kit je nový maskot webového prohlížeče Firefox.

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

    Mastodon (Wikipedie) - sociální síť, která není na prodej - byl vydán ve verzi 4.5. Přehled novinek s náhledy v oznámení na blogu.

    Ladislav Hagara | Komentářů: 1
    6.11. 23:55 | IT novinky

    Německo zvažuje, že zaplatí místním telekomunikačním operátorům včetně Deutsche Telekom, aby nahradili zařízení od čínské firmy Huawei. Náklady na výměnu by mohly přesáhnout dvě miliardy eur (bezmála 49 miliard Kč). Jeden scénář počítá s tím, že vláda na tento záměr použije prostředky určené na obranu či infrastrukturu.

    Ladislav Hagara | Komentářů: 1
    6.11. 18:00 | Komunita

    Po dvaceti letech skončil leader japonské SUMO (SUpport.MOzilla.org) komunity Marsf. Důvodem bylo nasazení sumobota, který nedodržuje nastavené postupy a hrubě zasahuje do překladů i archivů. Marsf zároveň zakázal použití svých příspěvků a dat k učení sumobota a AI a požádal o vyřazení svých dat ze všech učebních dat.

    karkar | Komentářů: 8
    6.11. 11:00 | IT novinky

    Úřad pro ochranu hospodářské soutěže zahajuje sektorové šetření v oblasti mobilních telekomunikačních služeb poskytovaných domácnostem v České republice. Z poznatků získaných na základě prvotní analýzy provedené ve spolupráci s Českým telekomunikačním úřadem (ČTÚ) ÚOHS zjistil, že vzájemné vztahy mezi operátory je zapotřebí detailněji prověřit kvůli možné nefunkčnosti některých aspektů konkurence na trzích, na nichž roste tržní podíl klíčových hráčů a naopak klesá význam nezávislých virtuálních operátorů.

    Ladislav Hagara | Komentářů: 16
    6.11. 10:55 | Humor

    Různé audity bezpečnostních systémů pařížského muzea Louvre odhalily závažné problémy v oblasti kybernetické bezpečnosti a tyto problémy přetrvávaly déle než deset let. Jeden z těchto auditů, který v roce 2014 provedla francouzská národní agentura pro kybernetickou bezpečnost, například ukázal, že heslo do kamerového systému muzea bylo „Louvre“. 😀

    Ladislav Hagara | Komentářů: 15
    6.11. 01:00 | Komunita

    Z upstreamu GNOME Mutter byl zcela odstraněn backend X11. GNOME 50 tedy poběží už pouze nad Waylandem. Aplikace pro X11 budou využívat XWayland.

    Ladislav Hagara | Komentářů: 19
    Jaké řešení používáte k vývoji / práci?
     (35%)
     (48%)
     (18%)
     (17%)
     (22%)
     (15%)
     (21%)
     (16%)
     (16%)
    Celkem 322 hlasů
     Komentářů: 15, poslední 2.11. 08:25
    Rozcestník

    Dotaz: Konverze string -> integer

    22.10.2011 11:39 Milan63
    Konverze string -> integer
    Přečteno: 598×
    Resim problem konverze stringu na integer, pouzivam tuto funkci:
    int str2int(string value)
    {
        int number;
        
        if(sscanf(value.c_str(), "%d", &number) == EOF)
        {
            cerr << "Input file is not in correct format" << endl;
            exit(EXIT_FAILURE);
        }
              
        return number;
    }
    
    Ta funguje v poradku, pokud prevadim napr. "123", pokud do teto funkce ale poslu napriklad retezec "xxx", vrati mi nejake zaporne cislo (misto toho, aby skoncila chybou). Jak tedy mohu tuto funkci opravit, aby mi v pripade nevalidniho vstupu tuto skutecnost opravdu zahlasila?

    Řešení dotazu:


    Odpovědi

    22.10.2011 11:57 rastos | skóre: 63 | blog: rastos
    Rozbalit Rozbalit vše Re: Konverze string -> integer
    Nainicializuj number na hodnotu, ktorú to má vrátiť, keď sa vstup na číslo skonvertovať nedá. Alebo výsledok sscanf() kontroluj nielen na EOF ale aj na nulu.
    22.10.2011 11:59 Kit
    Rozbalit Rozbalit vše Re: Konverze string -> integer
    Vypiš si návratovou hodnotu funkce sscanf() a bude ti to jasné hned. Zřejmě je chybou ji testovat na konstantu EOF, když na konec souboru nenarazila.

    V jakém je to vlastně jazyku?
    24.10.2011 10:45 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: Konverze string -> integer
    Já tomu říkám „C+“ .
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    24.10.2011 12:14 Kit
    Rozbalit Rozbalit vše Re: Konverze string -> integer
    Zkusil jsem si to po úpravách v C (protože v C a C++ skoro nic nedělám) a vyšlo mi, že kdž v podmínce místo ==EOF bude <=0, tak by to mělo fungovat.

    Na příkladu je vidět, jak nebezpečné může být používání neinicializovaných proměnných.
    24.10.2011 12:58 l4m4
    Rozbalit Rozbalit vše Re: Konverze string -> integer
    Pouze v případě, že se bude převádět právě jedna hodnota. Viz můj dva dny starý příspěvek...
    24.10.2011 13:03 Kit
    Rozbalit Rozbalit vše Re: Konverze string -> integer
    Jasně. Aby to bylo správně i logicky, mělo by být spíš <1, pokud očekávám jednu hodnotu, <3, pokud očekávám 3 hodnoty apod.
    24.10.2011 15:12 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: Konverze string -> integer
    No to bych raději volil != 1, to je přesnější.

    Ale jinak pokud by to mělo být C++, ne jen C+, tak by to mohlo být třeba takto:
    int str2int(std::string value)
    {
      std::istringstream iss(value);
      int number;
      if((iss >> number).fail())
      {
        std::cerr << "The input number is in a invalid format" << std::endl;
        exit(3);//or throw a exception…
      }
      return number;
    }
    
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    22.10.2011 16:16 l4m4
    Rozbalit Rozbalit vše Re: Konverze string -> integer
    Tak funkce to samozřejmě hlásí, a to tak, že vrátí nulu, protože proběhlo celkem nula úspěšných konverzí. Viz dokumentaci. EOF vrací funkce z rodiny scanf() pouze v případě, kdy nejde číst vstup, což zrovna u sscanf() moc nenastává.

    Jinak tenhle prapodivný mix C a C++ taky nechápu.
    24.10.2011 12:25 petrz
    Rozbalit Rozbalit vše Re: Konverze string -> integer
    ja by ch na to pouzil funkci atoi. (pokud ovsem neni cilem "udelej si sam")
    24.10.2011 13:00 l4m4
    Rozbalit Rozbalit vše Re: Konverze string -> integer
    S atoi() je kontrola chyb konverze opravdu jednoduchá, jelikož žádnou kontrolu nedělá ;)

    Šlo by ale samozřejmě použít strtol() a podobné.

    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.