abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 10:44 | Zajímavý článek

    Alyssa Rosenzweig se v příspěvku na svém blogu Vulkan 1.3 na M1 za 1 měsíc rozepsala o novém Vulkan 1.3 ovladači Honeykrisp pro Apple M1 splňujícím specifikaci Khronosu. Vychází z ovladače NVK pro GPU od Nvidie. V plánu je dále rozchodit DXVK a vkd3d-proton a tím pádem Direct3D, aby na Apple M1 s Asahi Linuxem běžely hry pro Microsoft Windows.

    Ladislav Hagara | Komentářů: 2
    dnes 01:00 | Nová verze

    Byla vydána (𝕏) květnová aktualizace aneb nová verze 1.90 editoru zdrojových kódů Visual Studio Code (Wikipedie). Přehled novinek i s náhledy a animovanými gify v poznámkách k vydání. Ve verzi 1.90 vyjde také VSCodium, tj. komunitní sestavení Visual Studia Code bez telemetrie a licenčních podmínek Microsoftu.

    Ladislav Hagara | Komentářů: 0
    dnes 00:44 | Nová verze

    Byla vydána (Mastodon, 𝕏) nová verze 2024.2 linuxové distribuce navržené pro digitální forenzní analýzu a penetrační testování Kali Linux (Wikipedie). Přehled novinek se seznamem nových nástrojů v oficiálním oznámení.

    Ladislav Hagara | Komentářů: 0
    včera 16:44 | IT novinky

    Počítačová hra Tetris slaví 40 let. Alexej Pažitnov dokončil první hratelnou verzi 6. června 1984. Mezitím vznikla celá řada variant. Například Peklo nebo Nebe. Loni měl premiéru film Tetris.

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

    MicroPython (Wikipedie), tj. implementace Pythonu 3 optimalizovaná pro jednočipové počítače, byl vydán ve verzi 1.23.0. V přehledu novinek je vypíchnuta podpora dynamických USB zařízení nebo nové moduly openamp, tls a vfs.

    Ladislav Hagara | Komentářů: 0
    včera 10:22 | Nová verze

    Canonical vydal Ubuntu Core 24. Představení na YouTube. Nová verze Ubuntu Core vychází z Ubuntu 24.04 LTS a podporována bude 12 let. Ubuntu Core je určeno pro IoT (internet věcí) a vestavěné systémy.

    Ladislav Hagara | Komentářů: 2
    včera 01:00 | Nová verze Ladislav Hagara | Komentářů: 0
    4.6. 19:55 | IT novinky

    Intel na veletrhu Computex 2024 představil (YouTube) mimo jiné procesory Lunar Lake a Xeon 6.

    Ladislav Hagara | Komentářů: 0
    4.6. 13:44 | IT novinky

    Na blogu Raspberry Pi byl představen Raspberry Pi AI Kit určený vlastníkům Raspberry Pi 5, kteří na něm chtějí experimentovat se světem neuronových sítí, umělé inteligence a strojového učení. Jedná se o spolupráci se společností Hailo. Cena AI Kitu je 70 dolarů.

    Ladislav Hagara | Komentářů: 0
    4.6. 13:22 | Nová verze

    Byla vydána nová verze 14.1 svobodného unixového operačního systému FreeBSD. Podrobný přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    Rozcestník

    Dotaz: Prace se souborem C

    4.3.2020 22:55 Dooyer
    Prace se souborem C
    Přečteno: 1165×
    int main(void) {
        int a = 0, b = 0, soucet = 0, polea[11];
        char c, poleb[11];
        FILE *fr;
        int d;
    

    if((fr = fopen("ctvrtek.txt","r")) == NULL) { printf("Soubor se nepodarilo otevrit!!\n"); return 1; } while((c = getc(fr)) != EOF) { if(c >= '0' && c <= '9') { poleb[a] = c; a = a + 1; } else { if(poleb[0] != '\0' && a != 0) { //plati pokud je v poli znak a a nesmi byt 0 polea[b] = atoi(poleb); for(d = 0; d <= 11; d++) { poleb[d] = '\0'; } a = 0; b = b + 1; } } } if(poleb[0] != '\0') { polea[b] = atoi(poleb); }

    if(fclose(fr) == EOF) { printf("Soubor se nepodarilo zavrit!!\n"); return 1; }

    for(d = 0; d < b; d++) { printf("%d. vysledne cislo: %d\n", d+1, polea[d]); soucet = soucet + polea[d]; }

    printf("Soucet: %d", soucet);

    return EXIT_SUCCESS; }

    Tady konkrétně nerozumím proč v tom programu má být

    for(d = 0; d <= 11; d++) {
                        poleb[d] = '\0';
                    }
    

    Proč ten nulový znak(ukončení řetezce) má být za každým znakem? ukončuje se celý řetězec ne? proč 11x?

    a potom
     if(poleb[0] != '\0') {
            polea[b] = atoi(poleb);
        }
    

    Odpovědi

    4.3.2020 23:08 Dooyer
    Rozbalit Rozbalit vše Re: Prace se souborem C
    nevím jak ten text uspořádat aby se v tom dalo orientovat
    Max avatar 4.3.2020 23:09 Max | skóre: 72 | blog: Max_Devaine
    Rozbalit Rozbalit vše Re: Prace se souborem C
    Opraveno.
    Zdar Max
    Měl jsem sen ... :(
    4.3.2020 23:13 Dooyer
    Rozbalit Rozbalit vše Re: Prace se souborem C
    Jen si mi přehodil ty texty k tomu kodu :D ten horní text má být kté spodní části kodu
    Max avatar 5.3.2020 12:14 Max | skóre: 72 | blog: Max_Devaine
    Rozbalit Rozbalit vše Re: Prace se souborem C
    Nic jsem nepřehodil. Jen jsem zvýraznil kód, nic víc.
    Zdar Max
    Měl jsem sen ... :(
    4.3.2020 23:34 Michal Kubeček | skóre: 72 | Luštěnice
    Rozbalit Rozbalit vše Re: Prace se souborem C

    První problém je chybějící kontext, takže budu předpokládat, že jste dostal cizí program a snažíte se přijít na to, co dělá. Odpověď je, že přečte vstupní soubor, vytahá z něj souvislé posloupnosti číslic, převede je na čísla, ta čísla vypíše a sečte.

    Co se týká těch dvou fragmentů, tak první prostě vyplní poleb nulovými znaky, než do něj začne načítat další posloupnost číslic. Tenhle krok byste si samozřejmě mohl odpustit, pokud byste před převodem (tj. při první nečíslici nebo na konci souboru, pokud končil číslicí) ten nulový znak na konec připsal.

    Druhý fragment převede poslední posloupnost číslic v případě, že za ní nebyl jiný znak, ale sahala až do konce souboru. Tady je ale chyba, protože autor zapomněl inkrementovat b, takže to poslední číslo se v takovém případě nevypíše a nezapočítá do součtu.

    Těch chyb je tam víc, např. chybí kontrola, že posloupnost číslic nemá víc než 10 znaků (má-li 11, předáte atoi() neukončený řetězec, má-li víc, přeteče vám to už při zápisu do poleb). Stejně tak chybí kontrola, že těch čísel tam není víc než 11 (jinak přeteče polea). A pokud soubor bude začínat něčím jiným než číslicí, máte tam čtení z neinicializovaného poleb[0]. V kontrastu s tím působí úsměvně snaha pečlivě ošetřit a nahlásit selhání fclose(), což je vysoce nepravděpodobný scénář, stejně s tím nic nenaděláte, stejně se soubor nakonec zavře při ukončení programu a protože byl otevřený pro čtení, nebude to ani ničemu vadit.

    Další problém je

      while((c = getc(fr)) != EOF)
    

    kde c je char a ne int. Při troše štěstí to možná fungovat bude, ale i pak to bude hodně záviset na konkrétní verzi překladače a libc (a nejspíš i architektuře).

    4.3.2020 23:42 Dooyer
    Rozbalit Rozbalit vše Re: Prace se souborem C
    Tak ty znaky se pak převedou na hodnoty pomocí atoi a hodí se do pole int jako funguje m ito
    4.3.2020 23:51 Michal Kubeček | skóre: 72 | Luštěnice
    Rozbalit Rozbalit vše Re: Prace se souborem C

    Jestli mluvíte o tom chybějícím b++ tak problém není v tom, že by se číslice nepřevedly a neuložily, ale v tom, že neaktualizujete proměnnou b, kde máte počet prvků polea (mimochodem, a pro počet prvků poleb a b pro počet prvků polea je opravdu vynalézavé), takže následující smyčka to poslední číslo nezpracuje.

    Samozřejmě to ale nastane jen v případě, že máte číslice opravdu až na konci souboru, ne pokud za nimi bude ještě např. newline ('\n').
    5.3.2020 00:04 Dooyer
    Rozbalit Rozbalit vše Re: Prace se souborem C
    jj takze tam stačí pred převod hodit jen poleb[a]=ˇ\0ˇ
    5.3.2020 00:40 Dooyer
    Rozbalit Rozbalit vše Re: Prace se souborem C
    a jak to mám udělat aby to poslední číslo zpracovalo?
    5.3.2020 07:22 Michal Kubeček | skóre: 72 | Luštěnice
    Rozbalit Rozbalit vše Re: Prace se souborem C

    Nejjednodušší je prostě navíc inkrementovat b, např.

    if (poleb[0] == '\0') {
            polea[b] = atoi(poleb);
            b++;
    }
    

    což bych asi spíš přepsal

    if (!poleb[0])
            polea[b++] = atoi(poleb);
    

    ale to už by asi bylo lepší to celé přepsat úplně od základu. Např. ani jedno z těch polí ve skutečnosti není potřeba (tím odpadnou i problémy s nehlídaným přetečením), open coding věci jako isdigit() nebo memset() vede jen k horší čitelnosti a zvyšuje riziko chyb atd. Podle těch podivných jmen proměnných to ale skoro vypadá, jako by nečitelnost byla cílem.

    5.3.2020 00:42 Andrej | skóre: 51 | blog: Republic of Mordor
    Rozbalit Rozbalit vše Re: Prace se souborem C
    Při troše štěstí to možná fungovat bude, ale i pak to bude hodně záviset na konkrétní verzi překladače a libc (a nejspíš i architektuře).

    Celkem bez závislosti na libc a překladači a architektuře to prostě selže, pokud v souboru bude byte 0xff. (Pravda, teoreticky by mohlo být EOF != -1, ale to by bylo hodně překvapivé. Navíc by to chybu neodstranilo, protože by se ten EOF prostě „převedl“ (poněkud ztrátově) zase na jiný specifický char, který by se pak mylně pokládal za konec souboru.)

    Zkrátka, tohle bude mylně považovat byte s hodnotou 0xff (255, bráno bez znaménka, nebo -1, bráno se znaménkem) za konec souboru, protože obvykle EOF == -1 a char je znaménkový.

    Že getc() vrací int, nikoliv char, k tomu je přesně tenhle důvod.

    char c: byte 0xff bude -1 (== EOF)
    int c: byte 0xff bude 255 (!= EOF)

    5.3.2020 01:13 Dooyer
    Rozbalit Rozbalit vše Re: Prace se souborem C
    vsak d < b //indexuje se od 0.. co je na tom blbě? kdyz bude 6 prvku d<6 je to ok
    5.3.2020 09:10 Michal Kubeček | skóre: 72 | Luštěnice
    Rozbalit Rozbalit vše Re: Prace se souborem C

    Tady je řeč o něčem jiném: o testu konce souboru. Funkce getchar() vrací int (a ne char) právě proto, aby bylo možné mít speciální hodnotu pro EOF, která se liší od toho, co getchar() vrátí pro kterýkoli skutečný znak (nebo spíš byte).

    Pokud ještě před testem na EOF návratovou hodnotu převedete na char, EOF se nutně převede na stejnou hodnotu jako některý skutečný byte, který se v souboru může vyskytnout. V závislosti na tom, jak napíšete to porovnání, a na implementaci getchar(), char a EOF pak buď budete mít byte, který (pokud se v souboru vyskytne) vyhodnotíte jako konec, nebo nepoznáte ten skutečný EOF.

    5.3.2020 08:26 Michal Kubeček | skóre: 72 | Luštěnice
    Rozbalit Rozbalit vše Re: Prace se souborem C
    protože obvykle EOF == -1 a char je znaménkový

    Tohle je právě to uvažování, kterému je lepší se vyhnout. Na jedné straně sice opravdu obskurních prostředí ubývá, ale na druhé mají moderní překladače tendenci využívat k agresivním optimalizacím i toho, že něco je ve specifikaci uvedeno jako undefined behavior. Někde jsem narazil na příklad, že smyčku

            int i;
    
            for (i = 1; i; i++) {
                    ...
            }
    

    může takový překladač úplně vyhodit, protože chování při přetečení je u unsigned typů undefined behavior. A může to udělat i překladač, který jinak int a operace s ním implementuje tím obvyklým způsobem, při kterém se to na tu nulu nakonec dostane. (Aktuální gcc to nedělá, aspoň ne defaultně, ale při zapnuté optimalizaci už vyhodí warning.)

    Osobně char používám jen tam, kde prvky opravdu chci chápat jako znaky; pokud s nimi chci pracovat jako s čísly, pak raději uint8_t a int8_t (resp. u8 a s8).

    6.3.2020 14:18 Andrej | skóre: 51 | blog: Republic of Mordor
    Rozbalit Rozbalit vše Re: Prace se souborem C
    protože obvykle EOF == -1 a char je znaménkový

    Tohle je právě to uvažování, kterému je lepší se vyhnout.

    Není vůbec nic špatného na úvaze, co například může být EOF a co může vzniknout jeho konverzí na char. Špatné by bylo počítat automaticky s tím, že EOF je -1, což ale nikde neradím. Naopak říkám, že bez ohledu na definici EOF to nebude nikdy správně fungovat. Kterýkoliv byte vzniklý konverzí EOF na char (ať už to bude 0xff nebo jiný) bude chybně považovaný za konec souboru.

    Gréta avatar 6.3.2020 14:49 Gréta | skóre: 36 | blog: Grétin blogísek | 🇮🇱==❤️ , 🇵🇸==💩 , 🇪🇺==☭
    Rozbalit Rozbalit vše Re: Prace se souborem C

    proč jako používat čísílka když už jako máme definovaný tamto makro eof :O :D

    joa taky je tam jako někde taková ta funkcička feof ;D

    6.3.2020 18:11 Andrej | skóre: 51 | blog: Republic of Mordor
    Rozbalit Rozbalit vše Re: Prace se souborem C
    proč jako používat čísílka když už jako máme definovaný tamto makro eof :O :D

    Nikdo v celém tomto vlákně nenavrhoval, ba ani nenaznačoval, že by se někde měla "používat" nějaká čísla. Pak je otázka, na co vlastně reaguješ.

    joa taky je tam jako někde taková ta funkcička feof ;D

    Což může být fajn, když čtu víc souborů najednou a chci se později podívat, které už jsem dočetl. (Třeba příkaz paste by něco takového mohl s výhodou použít.) Nicméně pro jeden soubor čtený v jednom cyklu [tento případ] je overkill volat po každém znaku feof(). Stačí brát z fgetc() správný návratový typ (int) a EOF se pak nebude rovnat žádnému jednomu bytu.

    Gréta avatar 7.3.2020 13:28 Gréta | skóre: 36 | blog: Grétin blogísek | 🇮🇱==❤️ , 🇵🇸==💩 , 🇪🇺==☭
    Rozbalit Rozbalit vše Re: Prace se souborem C

    sorry sem to jenom přelítla vočima a vidim eof==-1 :O :O ;D

    co se jako týká tý feof tak jsem jako myslela že se jako řeší nějakej paranoidní scénář kdy se nějak nedá jakoby 100% spolehnout jenom na eof a nato se fukncička feof hodí protože vona nekouká na znak eof vona kouká o malililinkaťoučkej kousíček dál hele :O :O :O :O ;D

    The function feof() is used to check the end of file after EOF. It tests the end of file indicator. It returns non-zero value if successful otherwise, zero.

    ale jako žeto je pro dooyerův domácák overkill toje jako jasný ;D

    Jendа avatar 6.3.2020 23:43 Jendа | skóre: 78 | blog: Jenda | JO70FB
    Rozbalit Rozbalit vše Re: Prace se souborem C
    chování při přetečení je u unsigned typů undefined behavior
    Signed, ne? U unsigned to legálně přeteče na nulu.
    6.3.2020 23:53 Michal Kubeček | skóre: 72 | Luštěnice
    Rozbalit Rozbalit vše Re: Prace se souborem C
    Ano. Jak jsem tu větu přeformuloval, zůstalo tam něco jiného než mělo.
    4.3.2020 23:37 Dooyer
    Rozbalit Rozbalit vše Re: Prace se souborem C
    Jako program mi funguje i bez

    if(poleb[0] != '\0') { polea[b] = atoi(poleb); }
    Gréta avatar 5.3.2020 07:50 Gréta | skóre: 36 | blog: Grétin blogísek | 🇮🇱==❤️ , 🇵🇸==💩 , 🇪🇺==☭
    Rozbalit Rozbalit vše Re: Prace se souborem C
    Gréta avatar 5.3.2020 07:53 Gréta | skóre: 36 | blog: Grétin blogísek | 🇮🇱==❤️ , 🇵🇸==💩 , 🇪🇺==☭
    Rozbalit Rozbalit vše Re: Prace se souborem C

    taky tam jako neni vošetřený přetečení proměný když ty čísla budou moc velký ;D

    1. vysledne cislo: 1234567680
    2. vysledne cislo: 1234585655
    3. vysledne cislo: 371679162
    4. vysledne cislo: 1360599260
    5. vysledne cislo: 454554
    6. vysledne cislo: 555
    7. vysledne cislo: 4545445
    Soucet: -88534985
    
    ale teď už jako fakt musim běžet :O :'(
    Gréta avatar 5.3.2020 13:42 Gréta | skóre: 36 | blog: Grétin blogísek | 🇮🇱==❤️ , 🇵🇸==💩 , 🇪🇺==☭
    Rozbalit Rozbalit vše Re: Prace se souborem C

    mý řešení dooyerova domácáku :D :D

    #include <stdio.h>
    #include <stdlib.h>
    #include <errno.h>
    #include <limits.h>
    
    int main ( void )
    {
    
        //soubor
        FILE * fr=NULL;
    
        //přečtenej řádek ze souboru
        char * radek = NULL;
    
        //velikost bufferu kterej si alokuje getline pro čtení řádku
        size_t velikostBufferu = 0;
    
        //kolik jako sme přečetli znaků :O
        //to ssize je jakoby signed size_t takže muže bejt záporná :O :O
        ssize_t read;
    
        //sem si to jako budeme sčítat všecko
        long suma=0;
    
    
        if ( ( fr = fopen ( "input.txt","r" ) ) == NULL ) {
            fprintf ( stderr,"Soubor se nepodarilo otevrit!!\n" );
            exit ( EXIT_FAILURE );
        }
    
        //budem číst soubor řádek po řádečku ;D
        //getline přečte řádek do proměný radek
        //pokud to nepude vrátí -1
        //třeba když jako máme to EOF
        //víc o getline tady https://linux.die.net/man/3/getline
        while ( ( read = getline ( &radek, &velikostBufferu, fr ) ) != -1 ) {
    
            printf ( "zpracovava se retezec: %s",radek );
    
            //tady jako dost dobře mužem předpokládat nějakou hezkou chybku
            //proměná errno z errno.h drží číslo poslední chyby
            //vynulujem jestli tam už něco bylo předem
            //nulička znamená jako dobrý žádná chyba ;D
            errno=0;
    
            //teďko si to převedem funkcí strtol na číslo ;D
            //https://linux.die.net/man/3/strtol
            //první argument je řetězec znaků
            //druhej je takovej endptr ten drží první nečíselnej znak na kterej funkce narazí. pokud obsahuje vstupní string tak sme jako nenašli žádný čísla!!!! :O :O
            //posledním argumentem nastavujem aby to jako počítalo s číslem v desítkový soustavě ;D
            char * endptr;
            long hodnota = strtol ( radek, &endptr, 10 );
    
    
            //kouknem do proměný errno jestli se nám to jako povedlo
            //kódový číslo ERANGE řiká že hodnota je jako mimo povolenej rosach
            if ( ( errno == ERANGE && ( hodnota == LONG_MAX || hodnota == LONG_MIN ) ) ) {
                //perror ( "strtol" ); //profík by použil perror ;D
                //hele https://linux.die.net/man/3/perror
                fprintf ( stderr, "out of range chyba!!!!\n" );
                exit ( EXIT_FAILURE );
            } 
            //tady budem chytat tak nějak obecně :D
            else if ( errno != 0 && hodnota == 0 ) {
                fprintf ( stderr, "chyba!!!!\n" );
                exit ( EXIT_FAILURE );
            }
    
            if ( endptr == radek ) {
                fprintf ( stderr, "zadny nalezeny cisla v stringu jako!!\n" );
                exit ( EXIT_FAILURE );
            }
    
            //a teď si jako přičtem hodnotu k sumě s tim že budem aspoň trošku hlídat overflow
            long origSuma=suma;
            suma+=hodnota;
            if ((hodnota>0 && origSuma>0 && suma<0)||(hodnota<0 && origSuma<0 && suma>0)) {
                fprintf ( stderr, "preteceni promeny suma jako!!\n" );
                exit ( EXIT_FAILURE );
            }
    
            //všecko vypišeme
            printf ( "hodnota: %ld\nvelikost bufferu: %zd\n(int)endptr: %d\nsuma: %ld\n\n",hodnota,velikostBufferu, ( int ) ( *endptr ),suma );
        }
    
        if ( radek ) {
            free ( radek );    //uklídíme po sobě paměť řádku
        }
    
    
        if ( fclose ( fr ) != 0 ) {
            fprintf ( stderr,"Soubor se nepodarilo zavrit!!\n" );
            exit ( EXIT_FAILURE );
        }
    
        printf ( "hotovo!!!!!!!!!!!!!!!!!!!!!!!!!!!\n" );
    
        return EXIT_SUCCESS;
    }
    

    a jako s pravdou ven že se potobě chce sčítat ty dlouhatatánský  člísla ve stringzích pod sebe?? ;D

    5.3.2020 15:36 _
    Rozbalit Rozbalit vše Re: Prace se souborem C
    No když už nic jinýho, tak jsme si dokázali že Gréta není Bystroushaak, ten by strachem před céčkem zalezl pod postel, popř. by sesmolil hnus, velebnosti.
    Gréta avatar 6.3.2020 14:37 Gréta | skóre: 36 | blog: Grétin blogísek | 🇮🇱==❤️ , 🇵🇸==💩 , 🇪🇺==☭
    Rozbalit Rozbalit vše Re: Prace se souborem C

    třeba jako sem zalezlá pod postelí a strašně se snažim nesesmolit hnus :O :O :D :D

    9.3.2020 23:56 Franta
    Rozbalit Rozbalit vše Re: Prace se souborem C
    Zdarec Miriam
    Gréta avatar 10.3.2020 10:43 Gréta | skóre: 36 | blog: Grétin blogísek | 🇮🇱==❤️ , 🇵🇸==💩 , 🇪🇺==☭
    Rozbalit Rozbalit vše Re: Prace se souborem C

    sem si tu miriam jenom pučila na dělání bordýlku jinak jako vo ni vim asi tolik co ty vo mě :O ;D

    10.3.2020 00:03 Franta
    Rozbalit Rozbalit vše Re: Prace se souborem C
    Ta kontrola preteceni a podteceni sumy je spatne, dochazi tu k UB a muze to smazat disk.
    Gréta avatar 10.3.2020 10:40 Gréta | skóre: 36 | blog: Grétin blogísek | 🇮🇱==❤️ , 🇵🇸==💩 , 🇪🇺==☭
    Rozbalit Rozbalit vše Re: Prace se souborem C

    na disku mam zatim ještě všecko tak nevim :D :D

    ale jako máš pravdu stim undefined behavior lepší je tomu overflow jakoby předejít než koukat jestli se jako stalo tááákže

    #include <stdio.h>
    #include <stdlib.h>
    #include <limits.h>
    
    int add ( long * k_cemu,const long a_co_jako )
    {
        if ( ( *k_cemu>0 && a_co_jako>LONG_MAX-*k_cemu ) || ( *k_cemu<0 && a_co_jako<LONG_MIN-*k_cemu ) ) {
            fprintf ( stderr,"pozor!!!!!!!!\nscitat %ld a %ld nebudu jako!!!!\nbylo by overflow/underflow!!!!!!!!\n",*k_cemu,a_c>
                      return EXIT_FAILURE;
        } else {
            *k_cemu+=a_co_jako;
        }
        return EXIT_SUCCESS;
    }
    
    int main ( void )
    {
        const long skoroMAX=LONG_MAX-1;
        const long minusSkoroMAX=LONG_MIN+1;
        long sum=0;
    
        while ( add ( &sum,skoroMAX ) !=EXIT_FAILURE ) {
            printf ( "sum: %ld\n" );
        }
        sum=0;
        while ( add ( &sum,minusSkoroMAX ) !=EXIT_FAILURE ) {
            printf ( "sum: %ld\n" );
        }
    
        return 0;
    }
    

    jo a je takový zajímavý že u unsigned se to muže dělat něco takovýho u unsigned ub neni :O :O :O :O

    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.