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 21:00 | Nová verze

    Po 9 týdnech vývoje od vydání Linuxu 7.0 oznámil Linus Torvalds vydání Linuxu 7.1. Přehled novinek a vylepšení na LWN.net: první a druhá polovina začleňovacího okna a časem také na Linux Kernel Newbies.

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

    Cheat Engine (Wikipedie) je s verzí 7.7 k dispozici už také pro Linux. Jedná se o proprietární skener/debugger paměti používaný především k cheatování v počítačových hrách.

    Ladislav Hagara | Komentářů: 0
    13.6. 15:22 | IT novinky

    Vláda USA nařídila společnosti Anthropic pozastavit přístup k modelům Fable 5 a Mythos 5 pro všechny cizince, včetně zaměstnanců Anthropicu.

    Ladislav Hagara | Komentářů: 6
    13.6. 02:22 | Nová verze

    Společnost Murena představila (YouTube) novou verzi 4.0 mobilního operačního systému /e/OS (Wikipedie) založeného na Androidu a LineageOS bez aplikací a služeb od Googlu.

    Ladislav Hagara | Komentářů: 0
    12.6. 16:33 | Bezpečnostní upozornění

    V Arch User Repository (AUR) bylo kompromitováno přes 400 opomíjených balíčků (jejich seznam). Útočník do nich začlenil škodlivý npm balíček atomic-lockfile, který krade citlivá data uživatelů. Publikována byla předběžná analýza spouštěného malwaru deps.

    Ladislav Hagara | Komentářů: 11
    12.6. 11:33 | Nová verze

    Homebrew, správce balíčků nejen pro macOS, byl vydán ve verzi 6.0.0 (seznam změn). Hlavními novinkami jsou bezpečnostní mechanismus tap trust kvůli důvěryhodnosti závislostí, vylepšení sandboxingu na Linuxu, interní JSON API nebo zlepšení výkonu.

    |🇵🇸 | Komentářů: 0
    12.6. 03:33 | Bezpečnostní upozornění

    Byla nalezena a 9. června opravena kritická zranitelnost ve FreeBSD v Kernel TLS (KTLS). Pojmenována byla Bumsrakete (FreeBSD-SA-26:26.ktls, CVE-2026-45257). Lokální neprivilegovaný uživatel může přepisovat soubory, ke kterým má právo pouze pro čtení. Přepsáním setuid binárky a jejím spuštěním může získat roota. Na všech verzích od verze 13.0 vydané v dubnu 2021.

    Ladislav Hagara | Komentářů: 2
    11.6. 14:11 | Komunita

    Vývojáři open source operačního systému ReactOS (Wikipedie), jehož cílem je kompletní binární kompatibilita s aplikacemi a ovladači pro Windows, se na síti 𝕏 pochlubili, že ReactOS zvládne počítačovou hru Half-Life.

    Ladislav Hagara | Komentářů: 5
    11.6. 10:44 | Nová verze

    Byla vydána nová verze 4.8 multiplatformního integrovaného vývojového prostředí (IDE) pro rychlý vývoj aplikaci (RAD) ve Free Pascalu Lazarus (Wikipedie). Využíván je Free Pascal Compiler (FPC) 3.2.2.

    Ladislav Hagara | Komentářů: 0
    11.6. 04:44 | Nová verze

    Apple container dospěl do verze 1.0.0. Jedná se o open source nástroj pro spouštění linuxových kontejnerů na macOS postavený nad containerization. Napsaný je v programovacím jazyce Swift a optimalizovaný pro Apple silicon.

    Ladislav Hagara | Komentářů: 5
    Které desktopové prostředí na Linuxu používáte?
     (11%)
     (8%)
     (2%)
     (16%)
     (31%)
     (3%)
     (6%)
     (3%)
     (15%)
     (26%)
    Celkem 1906 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    Rozcestník


    Dotaz: "blbuvydorne" nacitanie hodnoty do integeru, jazyk C

    11.12.2010 10:50 martin knocik | skóre: 14
    "blbuvydorne" nacitanie hodnoty do integeru, jazyk C
    Přečteno: 542×
    Prosim vas, som začiatočník, ako mam zabezpecit, že ked nacitavam hodnotu do premennej typu integer, a zadam namiesto celeho cisla nejaky znak, aby mi program sa nezasekol ?

    tu je ukažka programu kde chcem aby sa mi do matice nacitavali iba cele cisla, ktore mozu byt aj vačšie ako 9.

    printf("zadajte prvok %d. riadku a %d. stlpca\n", a+1, b+1);

    scanf("%d", &mat[a][b]); /*naplnenie matice hodnotami*/

    Ďakujem za pomoc.

    Odpovědi

    11.12.2010 11:19 Dr. Eddy | skóre: 9 | blog: glog | České Budějovice
    Rozbalit Rozbalit vše Re: "blbuvydorne" nacitanie hodnoty do integeru, jazyk C
    no, o nacteni se stara scanf - oznami ti navratovou hodnotou, kolik hodnot ulozil. Takze v tomhle pripade by ti mel vratit 1 (spravne) nebo 0 (kdyz tam nebylo cislo). viz wikipedii o scanfu :)
    11.12.2010 17:31 martin knocik | skóre: 14
    Rozbalit Rozbalit vše Re: "blbuvydorne" nacitanie hodnoty do integeru, jazyk C
    Skúšal som to neuspešne naprogramovať takto. Ide mi o to aby pri zadani neičoho ineho než čisla mi vypisalo chybu a mohol som znovu zadať cislo. To co som ja naprogramoval, tak tam ked zadam nieco ine ako cislo, začne donekonečna vypisovať "chyba, zadaj cislo". Neviete mi poradiť ako to spravne naprogramovať ?

    while ((scanf("%d", &a)) != 1) {

    printf("chyba, zadaj cislo");

    b = scanf("d", &a);

    }

    11.12.2010 18:40 Mr.S1lent.cz
    Rozbalit Rozbalit vše Re: "blbuvydorne" nacitanie hodnoty do integeru, jazyk C
    scanf je funkce v blokovacim rezimu, cili jej necpi do while, ten udelej normalne perzistentni: while( 1 ) a az v tom bloku kontroluj vstup pomoci scanf a if else za pomoci continue, popr break pro ukonceni cyklu :-)
    11.12.2010 18:45 Pavel Löbl | skóre: 7 | blog: vadnej_pixel
    Rozbalit Rozbalit vše Re: "blbuvydorne" nacitanie hodnoty do integeru, jazyk C
    Rekl bych, ze problem je spis vtom, ze pokud scanf nic nenacte necha vstupni data nedotcena ve vstupni bufferu. Takze pri dalsim cteni se pokousi znovu precist to stejne. Zkusil bych nacist cely radek (napr. fgets) pak na nej zavolal sscanf a pri neuspechu vypsal chybu a nacet dalsi radek.
    stativ avatar 13.12.2010 12:13 stativ | skóre: 54 | blog: SlaNé roury
    Rozbalit Rozbalit vše Re: "blbuvydorne" nacitanie hodnoty do integeru, jazyk C
    Tak tak. Take bych nacetl cely radek a az potom to kontroloval, napripklad pomoci strtol:
    char *endptr = num;
    errno = 0;
    strtol(num, &endptr);
    if (errno != 0) {
        // ERANGE
        // neni int, resp mimo rozsah
    }
    if (num == endptr) {
        // no characters consumed
        // neni int
    }
    if (*endptr != 0) {
        // trailing data
        // neni int
    }
    Ať sežeru elfa i s chlupama!!! ljirkovsky.wordpress.com stativ.tk
    14.12.2010 11:14 mato
    Rozbalit Rozbalit vše Re: "blbuvydorne" nacitanie hodnoty do integeru, jazyk C
    pri GNU C by si mohol pouzit getline .. ak pracujes na UX, mozes pouzit aj napr:
    
    #include <stdio.h>
    
    #define BUFSZ           1024
    
    #define MIN_INT         2
    #define MAX_INT         12
    
    int main()
    {
            char buf[BUFSZ+1];
            int a, fetch = 1;
    
            /* set a to out of range */
            a = ((MIN_INT)-1);
    
            while (fetch) {
                    fprintf (stdout, "?: ");
    
                    /* get line and format */
                    fgets((char*)&buf, BUFSZ, stdin);
                    sscanf (buf, "%d", &a);
    
                    /* check */
                    if ( (a >= MIN_INT) && (a <= MAX_INT) )  {
                            fetch = 0;
                    }
                    else {
                            fprintf (stderr, "error: integer out of range (<%d,%d>)\n", MIN_INT, MAX_INT);
                    }
            }
    
            fprintf (stdout, "your integer: %d\n", a);
            return 0;
    }
    
    pre "cistotu" kodu by som ten buf urobil dynamicky a oplatilo by sa chytit aj trapy na ^c, pripadne spravit mechanizmus na vyskocenie z nacitania (t.j. ukoncit program ak uzivatel nechce zadavat dalej cisla)

    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.