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 19:33 | Nová verze

Byla vydána nová major verze 2.9.0 multiplatformního svobodného frameworku pro zpracování obrazu G'MIC (GREYC's Magic for Image Computing, Wikipedie). Přehled novinek i s náhledy na PIXLS.US. Zmínit lze například generování moaré animací. Ukázka na YouTube.

Ladislav Hagara | Komentářů: 0
28.3. 17:33 | Zajímavý článek

Nová čísla časopisů od nakladatelství Raspberry Pi: MagPi 91 (pdf) a 92 (pdf), HackSpace 29 (pdf), Hello World 12 (pdf), Wireframe 33 (pdf), 34 (pdf) a 35 (pdf).

Ladislav Hagara | Komentářů: 1
28.3. 16:11 | IT novinky

Společnost FriendlyElec začala prodávat svůj nejnovější miniaturní jednodeskový počítač NanoPi R2S. Počítač v ceně 22 dolarů zaujme především dvěma Gigabit Ethernet porty.

Ladislav Hagara | Komentářů: 38
27.3. 07:00 | Zajímavý článek

David Malcolm se ve svém příspěvku na blogu vývojářů Red Hatu rozepsal o statické analýze a nové volbě -fanalyzer v GCC 10. Ukázkové příklady lze vyzkoušet také online na stránce Compiler Explorer.

Ladislav Hagara | Komentářů: 1
26.3. 20:22 | IT novinky

Český hydrometeorologický ústav doposud poskytoval data z meteorologických měření pouze za úplatu, přestože jde o veřejnou instituci. Dlouhodobě se tím zabýval Jan Cibulka, datový novinář Českého rozhlasu. Dosavadní praxe se však nyní mění – Cibulka syrová historická data získal a zveřejnil včetně vzorové žádosti dle zákona o právu na informace o životním prostředí. Podle chystaného zákona o zabezpečení hydrometeorologické služby by měla odpadnout i nutnost o data explicitně žádat.

Fluttershy, yay! | Komentářů: 67
26.3. 18:22 | IT novinky

Router Turris Omnia 2020 získal certifikaci FCC nezbytnou pro prodej na americkém trhu. S tím souvisí, že je nyní tento router k dostání také prostřednictvím internetového obchodu Amazon.com. Nová verze routeru, která je v nabídce za 334 USD, má stříbrný kovový design a je vybavena operačním systémem Turris OS 4.0. Mimo to jsou její součástí i automatické bezpečnostní aktualizace a nově také testovací verze nového systému zabezpečení Sentinel, který umožňuje ještě rychleji reagovat na síťové hrozby.

Ladislav Hagara | Komentářů: 2
26.3. 16:44 | Zajímavý software

Projekt KDE představuje nové uživatelské rozhraní Plasma Bigscreen pro využití s velkými obrazovkami pro přehrávání multimédií. Vedle technologií Plasma integruje také Mycroft k ovládání hlasem. Ke stažení je betaverze pro Raspberry Pi 4.

Fluttershy, yay! | Komentářů: 3
26.3. 15:11 | Zajímavý software

Microsoft aktualizoval dokumentaci ke svému bezpečnostnímu softwaru Microsoft Defender Advanced Threat Protection (Microsoft Defender ATP) for Linux. Aktuálně je k dispozici veřejná preview verze. Oficiálně podporovány jsou linuxové distribuce Red Hat Enterprise Linux, CentOS, Ubuntu, Debian, SUSE Linux Enterprise Server a Oracle Linux. Původně Windows Defender byl loni přejmenován na Microsoft Defender, poněvadž byl přenesen také na macOS.

Ladislav Hagara | Komentářů: 3
26.3. 07:00 | Zajímavý článek

Ars Technica rozebírá na open source cílenou FUD zprávu, kterou v reakci na začlenění ovladače pro souborový systém exFAT do jádra Linux (posvěcené Microsoftem) šíří firma Paragon Software, která nabízí mj. alternativní, komerční ovladače exFAT.

Fluttershy, yay! | Komentářů: 20
25.3. 14:55 | Upozornění

S touto zprávičkou bylo na AbcLinuxu vydáno přesně 25 000 zpráviček. První z nich vyšla 4. října 2003. Leoš Literák v ní oznámil, že AbcLinuxu nově podporuje také zprávičky.

Ladislav Hagara | Komentářů: 34
Se kterými dopady COVID-19 už jste se přímo osobně setkali?
 (3%)
 (53%)
 (38%)
 (38%)
 (36%)
 (6%)
 (20%)
Celkem 420 hlasů
 Komentářů: 43, poslední včera 20:38
Rozcestník

www.AutoDoc.Cz

Dotaz: Prace se souborem C

4.3. 22:55 Dooyer
Prace se souborem C
Přečteno: 818×
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. 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. 23:09 Max | skóre: 68 | blog: Max_Devaine
Rozbalit Rozbalit vše Re: Prace se souborem C
Opraveno.
Zdar Max
Měl jsem sen ... :(
4.3. 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. 12:14 Max | skóre: 68 | 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. 23:34 Michal Kubeček | skóre: 71 | 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. 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. 23:51 Michal Kubeček | skóre: 71 | 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. 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. 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. 07:22 Michal Kubeček | skóre: 71 | 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. 00:42 Andrej | skóre: 47 | blog: Republic of Mordor | Zürich
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. 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. 09:10 Michal Kubeček | skóre: 71 | 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. 08:26 Michal Kubeček | skóre: 71 | 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. 14:18 Andrej | skóre: 47 | blog: Republic of Mordor | Zürich
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. 14:49 Gréta | skóre: 19 | blog: Grétin blogísek | Stockholm
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. 18:11 Andrej | skóre: 47 | blog: Republic of Mordor | Zürich
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. 13:28 Gréta | skóre: 19 | blog: Grétin blogísek | Stockholm
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. 23:43 Jendа | skóre: 76 | blog: Výlevníček | 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. 23:53 Michal Kubeček | skóre: 71 | 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. 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. 07:50 Gréta | skóre: 19 | blog: Grétin blogísek | Stockholm
Rozbalit Rozbalit vše Re: Prace se souborem C
Gréta avatar 5.3. 07:53 Gréta | skóre: 19 | blog: Grétin blogísek | Stockholm
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. 13:42 Gréta | skóre: 19 | blog: Grétin blogísek | Stockholm
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. 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. 14:37 Gréta | skóre: 19 | blog: Grétin blogísek | Stockholm
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. 23:56 Franta
Rozbalit Rozbalit vše Re: Prace se souborem C
Zdarec Miriam
Gréta avatar 10.3. 10:43 Gréta | skóre: 19 | blog: Grétin blogísek | Stockholm
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. 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. 10:40 Gréta | skóre: 19 | blog: Grétin blogísek | Stockholm
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.