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 02:00 | Bezpečnostní upozornění

Byly zveřejněny (Project Zero, Intel, AMD, Arm) informace o dalších 2 bezpečnostních chybách v procesorech: variantě 3a aneb CVE-2018-3640 - Rogue System Register Read (RSRE) a variantě 4 aneb CVE-2018-3639 - Speculative Store Bypass (SSB). Podrobnosti o chybě CVE-2018-3639 například v příspěvku na blogu Red Hatu. Princip vysvětlen pomocí videa na YouTube.

Ladislav Hagara | Komentářů: 0
včera 19:44 | Zajímavý software

Spolek vpsFree.cz na svém blogu informuje, že přechází z OpenVZ na vpsAdminOS. Distribuce vpsAdminOS je založena na NixOS a not-os. Pokud provozujete OpenVZ Legacy a nevíte co dál, můžete zvážit vpsAdminOS, který je na migraci kontejnerů z OpenVZ připraven.

Ladislav Hagara | Komentářů: 4
včera 10:22 | Komunita

Minulý týden byla ze správce souborů (Files, Soubory, Nautilus) v GNOME odstraněna možnost spouštění aplikací. Po bouřlivé diskusi byla dnes tato možnost do správce souborů vrácena (commit).

Ladislav Hagara | Komentářů: 27
20.5. 22:44 | Nová verze

Ani ne po měsíci vývoje od vydání verze 2.10.0 byla vydána nová verze 2.10.2 svobodné aplikace pro úpravu a vytváření rastrové grafiky GIMP. Přehled novinek i s náhledy v oznámení o vydání. Opraveno bylo 44 chyb. Novinkou je podpora formátu HEIF (High Efficiency Image File Format) a dva nové filtry.

Ladislav Hagara | Komentářů: 46
20.5. 17:44 | Komunita

SFC (Software Freedom Conservancy) na svém blogu blahopřeje společnosti Tesla k prvnímu kroku k dodržování licence GPL. Tesla ve svých elektromobilech používá svobodný software. Změny ve zdrojovým kódech ale doteď veřejně nezveřejňovala. Změna nastala tento týden. Zdrojové kódy byly zveřejněny na GitHubu. Nejedná se zatím ale o kompletní odpovídající zdrojové kódy (CCS - complete corresponding source).

Ladislav Hagara | Komentářů: 14
19.5. 17:33 | Komunita

Společnost Purism informuje o aktuálním vývoji chytrého telefonu Librem 5, jenž by měl respektovat bezpečnost, svobodu a soukromí uživatelů. Telefon už umí telefonovat. Librem 5 by měl být k dispozici v lednu 2019. Předobjednat jej lze za 599 dolarů.

Ladislav Hagara | Komentářů: 32
19.5. 09:00 | Bezpečnostní upozornění

Společnost Qualys zveřejnila výsledky bezpečnostního auditu procps-ng, tj. balíčku s příkazy free, kill, pgrep, pidof, pkill, pmap, ps, pwdx, skill, slabtop, snice, sysctl, tload, top, uptime, vmstat, w a watch. Nalezeno bylo 7 bezpečnostních chyb (CVE-2018-1120, CVE-2018-1121, CVE-2018-1122, CVE-2018-1123, CVE-2018-1124, CVE-2018-1125 a CVE-2018-1126). Dvě z nich jsou zneužitelné k lokální eskalaci práv. Příslušné záplaty jsou již k dispozici v upstreamu.

Ladislav Hagara | Komentářů: 5
18.5. 06:44 | Nová verze

Byla vydána třiadvacátá alfa verze svobodné historické realtimové strategie 0 A.D. (Wikipedie). Kódový název této nejnovější verze je Ken Wood. Představení novinek v poznámkách k vydání a také na YouTube.

Ladislav Hagara | Komentářů: 3
18.5. 05:55 | Zajímavý článek

Tento týden se v Cambridge ve Velké Británii konal hackfest, který měl za cíl zlepšit výkon na GNOME postavených systémů na slabších počítačích. Hans de Goede například analyzoval spotřebu paměti jednotlivých komponent ve Fedora 28 Workstation na stroji s 2 GB RAM a pomocí kroků popsaných v článku Kde uspořit paměť ve Fedora Workstation na MojeFedora.cz snížil spotřebu paměti z 1,4 GB na 765 MB.

Ladislav Hagara | Komentářů: 10
17.5. 20:55 | Nová verze

Bram Moolenaar oznámil vydání verze 8.1 textového editoru Vim (Vi IMproved). Hlavní novinkou je integrovaný terminál.

Ladislav Hagara | Komentářů: 7
Používáte pro některé služby inetd?
 (34%)
 (24%)
 (42%)
Celkem 137 hlasů
 Komentářů: 4, poslední včera 12:56
    Rozcestník

    Dotaz: Postfixova kalkulacka v C: osetreni neplatnych vstupu

    tomes.io avatar 14.3.2012 21:38 tomes.io | skóre: 12 | blog: tomesh
    Postfixova kalkulacka v C: osetreni neplatnych vstupu
    Přečteno: 997×
    Ahoj, tvořím postfixovou kalkulačku a potýkám se s problémem, jak ošetřit neplatné vstupy (špatná čísla -123abc není číslo-, příliš málo operandů pro operátor, úplně prázdný vstup).

    Nize uvadim mou implementaci (bez definic fcí, pouze main, na pochopeni by to melo stacit). Ošetřil jsem případ dělení nulou a neplatného operátoru. Dotaz bych rozdělil do dvou:

    PRVNI - zaporna čísla:

    Tato podoba neumí pracovat se zápornými čísly - považuje je za neplatný vstup. Když však odstraním poslední ELSE s warningem:
               else {
    
                 printf("CHYBA: Neplatny vstup!\n");
                 exit(1);
    tak mi kalkulačka počítá snadno i se zápornými čísly, ale také načítá veškeré další znaky, které při výpočtu ignoruje, ale na vstupu by být neměly.

    Otázka tedy zní, jak tyto znaky odfiltrovat (či jinak ošetřit), aby na vstupu byla pouze čísla, platné operátory a vše ostatní by končilo errorem a koncem programu s příslušnou hláškou. Snad by se to dalo vyřešit nějakou vhodnou podmínkou na vstupu?

    DRUHY - málo nebo žádné znaky na vstupu:

    Zatím jsem nepřišel na to, jak ošetřit vstup, nak terém není nic, mezera, mezera a pouze číslo, mezera číslo a operátor. Prostě nedostatečný vstup. Stand nějak využít fci strncmp?

    Byl bych rád, kdybyste mě někdo nakopnuli správným směrem. Píšu to od rána a už mi to nemyslí :)

    Zde má dosavadní implementace.

    int main()
     {
         //int vysledek;
         int numInp;
         char vstup[15];
         int op;
         int vysledek = 0;
         int i;
         int end = 0;
         
         while(end != EOF){
    
             end = scanf("%s", vstup);   //Program postupně bude brát slova ze vstupu...
             if(end == EOF)
                 break;
    
    
    
         numInp = atoi(vstup);
    
         for(i = 0; i < strlen(vstup); i++){
    
             if(isdigit(vstup[i])) {     //pokud načetl číslo...
    
                 numInp = atoi(vstup);
                 push(numInp);           //...přidá jej na vrchol zásobníku...
    
             }
    
    
    
             else if(strlen(vstup) == 1){
    
                        switch(vstup[i])    /* ...pokud načetl operátor, vezme dvě čísla z vrcholu zásobníku,
                                            *aplikuje na ně načtený operátor a výsledek uloží zpět na zásobník.*/
                        {
                        case '+':
                            vysledek = push(pop() + pop());
                            break;
                        case '-':
                            op = pop();
                            vysledek = push(pop() - op);
                            break;
                        case '*':
                            vysledek = push(pop() * pop());
                            break;
                        case '/':
                            op = pop();
                            if (op == 0){                          
                                 printf("Nelze delit nulou\n");
                                 exit(1);
                               }
                            else
                            vysledek = push(pop() / op);
                            break;
                        default:
                            printf("CHYBA: Neplatny vstup!\n"); //všechny jiné znaky (jednoznakové) než výše uvedené operandy
                            exit(1);
                        }
                 }
    
               else {
    
                 printf("CHYBA: Neplatny vstup!\n"); // filtruje "smetí" typu sdf125, ale i záporná čísla
                 exit(1);
             }
    
           }
         }
    
         printf("%d\n", vysledek);
     return 0;
    }

    Řešení dotazu:


    Odpovědi

    15.3.2012 00:00 kuka
    Rozbalit Rozbalit vše Re: Postfixova kalkulacka v C: osetreni neplatnych vstupu
    To si musis vyjasnit, co vlastne potrebujes. Pokud najdes cislici, tak na to pustis atoi. To samozrejme neni optimalni, viz man atoi. Pokud je vstup primo od uzivatele, je treba ho neustale kontrlovat s jista paranoia je na miste. Tzn. napriklad nacitat tak dlouho, dokud jsou na vstupu cislice nebo desetinna tecka (unarni minus, scientific notace atd...) a terprve pak to prevadet na cislo. Podobne se osetri nespravna sekvence oparatoru (dvakrat plus za sebou) apod.
    16.3.2012 14:51 Sten
    Rozbalit Rozbalit vše Re: Postfixova kalkulacka v C: osetreni neplatnych vstupu
    atoi je zlo. Používejte strtol a příbuzené funkce.
    tomes.io avatar 16.3.2012 22:28 tomes.io | skóre: 12 | blog: tomesh
    Rozbalit Rozbalit vše Re: Postfixova kalkulacka v C: osetreni neplatnych vstupu
    Ano, strol to vyresil. Uzaviram tedy problem.
    tomes.io avatar 16.3.2012 22:49 tomes.io | skóre: 12 | blog: tomesh
    Rozbalit Rozbalit vše Re: Postfixova kalkulacka v C: osetreni neplatnych vstupu
    no tak koukam, ze ne uplne. pri odecitani napr 4 0 - mi to haze zaporny vysledek.
    tomes.io avatar 16.3.2012 23:12 tomes.io | skóre: 12 | blog: tomesh
    Rozbalit Rozbalit vše Re: Postfixova kalkulacka v C: osetreni neplatnych vstupu
    no, vyreseno, byla to jen drobnost :)
    Fuky avatar 16.3.2012 10:38 Fuky | skóre: 52 | blog: 4u
    Rozbalit Rozbalit vše Re: Postfixova kalkulacka v C: osetreni neplatnych vstupu
    $ man strtol strtod strtof strtold
    int main(int argc, char *argv[]) { int base; char *endptr, *str; long val; if (argc < 2) { fprintf(stderr, "Usage: %s str [base]\n", argv[0]); exit(EXIT_FAILURE); } str = argv[1]; base = (argc > 2) ? atoi(argv[2]) : 10; errno = 0; /* To distinguish success/failure after call */ val = strtol(str, &endptr, base); /* Check for various possible errors */ if ((errno == ERANGE && (val == LONG_MAX || val == LONG_MIN)) || (errno != 0 && val == 0)) { perror("strtol"); exit(EXIT_FAILURE); } if (endptr == str) { fprintf(stderr, "No digits were found\n"); exit(EXIT_FAILURE); } /* If we got here, strtol() successfully parsed a number */ printf("strtol() returned %ld\n", val); if (*endptr != '\0') /* Not necessarily an error... */ printf("Further characters after number: %s\n", endptr); exit(EXIT_SUCCESS); } $ ./a.out 123 strtol() returned 123 $ ./a.out ' 123' strtol() returned 123 $ ./a.out 123abc strtol() returned 123 Further characters after number: abc $ ./a.out 123abc 55 strtol: Invalid argument $ ./a.out '' No digits were found $ ./a.out 4000000000 strtol: Numerical result out of range
    tomes.io avatar 16.3.2012 14:54 tomes.io | skóre: 12 | blog: tomesh
    Rozbalit Rozbalit vše Re: Postfixova kalkulacka v C: osetreni neplatnych vstupu
    Fuky, diky za hint. strtol() je ta fce, kterou asi hledam. Zkusim a dam vedet.
    rADOn avatar 16.3.2012 13:49 rADOn | skóre: 44 | blog: bloK | Praha
    Rozbalit Rozbalit vše Re: Postfixova kalkulacka v C: osetreni neplatnych vstupu
    Nehledáš náhodou nějaký ten flex/bison nebo něco podobného?
    "2^24 comments ought to be enough for anyone" -- CmdrTaco
    tomes.io avatar 16.3.2012 14:20 tomes.io | skóre: 12 | blog: tomesh
    Rozbalit Rozbalit vše Re: Postfixova kalkulacka v C: osetreni neplatnych vstupu
    az doted, nez jsem si to diky tobe vygoolil, jsem o zadnem bisonu neslysel :)

    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.