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 14:44 | Nová verze

    Byla vydána nová verze 4.6 (𝕏, Bluesky, Mastodon) multiplatformního open source herního enginu Godot (Wikipedie, GitHub). Přehled novinek i s náhledy v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 0
    dnes 13:33 | Humor

    Rozsáhlá modernizace hardwarové infrastruktury Základních registrů měla zabránit výpadkům digitálních služeb státu. Dnešnímu výpadku nezabránila.

    Ladislav Hagara | Komentářů: 5
    dnes 13:11 | Nová verze

    Čínský startup Kimi představil open-source model umělé inteligence Kimi K2.5. Nová verze pracuje s textem i obrázky a poskytuje 'paradigma samosměřovaného roje agentů' pro rychlejší vykonávání úkolů. Kimi zdůrazňuje vylepšenou schopnost modelu vytvářet zdrojové kódy přímo z přirozeného jazyka. Natrénovaný model je dostupný na Hugging Face, trénovací skripty však ne. Model má 1 T (bilion) parametrů, 32 B (miliard) aktivních.

    NUKE GAZA! 🎆 | Komentářů: 2
    dnes 09:00 | IT novinky

    V Raspberry Pi OS lze nově snadno povolit USB Gadget Mode a díky balíčku rpi-usb-gadget (CDC-ECM/RNDIS) mít možnost se k Raspberry Pi připojovat přes USB kabel bez nutnosti konfigurování Wi-Fi nebo Ethernetu. K podporovaným Raspberry Pi připojeným do USB portu podporujícího OTG.

    Ladislav Hagara | Komentářů: 0
    dnes 03:33 | Komunita

    Konference Installfest 2026 proběhne o víkendu 28. a 29. března v budově FELu na Karlově náměstí v Praze. Přihlásit přednášku nebo workshop týkající se Linuxu, otevřených technologií, sítí, bezpečnosti, vývoje, programování a podobně lze do 18. února 0:15.

    Ladislav Hagara | Komentářů: 0
    dnes 03:22 | Komunita

    Fedora Flock 2026, tj. konference pro přispěvatele a příznivce Fedory, bude opět v Praze. Proběhne od 14. do 16. června. Na Flock navazuje DevConf.CZ 2026, který se uskuteční 18. a 19. června v Brně. Organizátoři konferencí hledají přednášející, vyhlásili Call for Proposals (CfP).

    Ladislav Hagara | Komentářů: 1
    dnes 03:11 | Zajímavý software

    Z80-μLM je jazykový model 'konverzační umělé inteligence' optimalizovaný pro běh na 8-bitovém 4Mhz procesoru Z80 s 64kB RAM, technologii z roku 1976. Model používá 2-bitovou kvantizaci a trigramové hashování do 128 položek, což umožňuje zpracování textu i při velmi omezené paměti. Natrénovaný model se vejde do binárního souboru velkého pouhých 40 KB. Tento jazykový model patrně neprojde Turingovým testem 😅.

    NUKE GAZA! 🎆 | Komentářů: 3
    včera 17:44 | IT novinky

    Digitální a informační agentura (DIA) na přelomu roku dokončila rozsáhlou modernizaci hardwarové infrastruktury základních registrů. Projekt za 236 milionů korun by měl zabránit výpadkům digitálních služeb státu, tak jako při loňských parlamentních volbách. Základní registry, tedy Registr práv a povinností (RPP), Informační systém základních registrů (ISZR) a Registr obyvatel (ROB), jsou jedním z pilířů veřejné správy. Denně

    … více »
    Ladislav Hagara | Komentářů: 5
    včera 17:33 | IT novinky

    Evropská komise (EK) zahájila nové vyšetřování americké internetové platformy 𝕏 miliardáře Elona Muska, a to podle unijního nařízení o digitálních službách (DSA). Vyšetřování souvisí se skandálem, kdy chatbot s umělou inteligencí (AI) Grok na žádost uživatelů na síti 𝕏 generoval sexualizované fotografie žen a dětí. Komise o tom dnes informovala ve svém sdělení. Americký podnik je podezřelý, že řádně neposoudil a nezmírnil rizika spojená se zavedením své umělé inteligence na on-line platformě.

    Ladislav Hagara | Komentářů: 11
    včera 15:11 | Komunita

    Bratislava OpenCamp pokračuje vo svojej tradícii a fanúšikovia otvorených technológií sa môžu tešiť na 4. ročník, ktorý sa uskutoční 25. 4. 2026 na FIIT STU v Bratislave. V súčasnosti prebieha prihlasovanie prednášok a workshopov – ak máte nápad, projekt, myšlienku, o ktoré sa chcete podeliť s komunitou, OpenCamp je správne miesto pre vás.

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (18%)
     (6%)
     (0%)
     (10%)
     (23%)
     (3%)
     (5%)
     (2%)
     (12%)
     (33%)
    Celkem 643 hlasů
     Komentářů: 17, poslední 22.1. 15:24
    Rozcestník

    Dotaz: fopen Segmentation fault C

    1.12.2011 18:45 stepan
    fopen Segmentation fault C
    Přečteno: 773×
    Ahoj,

    dostal jsem se do úzkých. Nemůžu otevřít soubor, vždy mi to vypíše segmentation fault. Během kompilování gcc žádný warning ani chybu nevypíše, behěm spuštění bohužel SIGSEGV. Gdb mi chybu hlásí na řádku s
    FILE *p_f=fopen("soubor.txt","r+");
    , soubor přitom soubor existuje. Dále mám
    	if(p_f==NULL){
    		
    		printf("Chyba pri otevirani souboru\n");
    		fclose(p_f);
    		
    	}
    . Všechny potřebné knihovny jsou inkluovány, tak nevím kde je chyba. Googlem brázdím něco přes hodinu a půl a na nic jsem nepřišel. Jen jsem zjistil, že je tam potřeba použít fce malloc, bohužel jsem začátečník, tak nevím jak dál. Používám pro studium knihu od K&R. Díky všem za nápady.

    Řešení dotazu:


    Odpovědi

    1.12.2011 18:56 Radovan
    Rozbalit Rozbalit vše Re: fopen Segmentation fault C
    Jak chceš zavřít soubor, který se ti nepodařilo otevřít?

    Já to dělám takhle:
        if ((vstup=fopen("soubor.txt","r")))
           {
           /* zpracování ... */
           fclose(vstup);
           }
        else
           printf("Nelze otevřít soubor pro čtení!\n\a");
    
    1.12.2011 19:38 stepan
    Rozbalit Rozbalit vše Re: fopen Segmentation fault C
    Nevím, jaksi mi to nefunguje, to bude nejspíše tím, že tam používám ještě funkci fgets. Tady je to celé
    if ((vstup=fopen("soubor.txt","r"))) {
    		
          if((fgets(pointer,10000000,vstup))==NULL) {
    		
    			printf("Chyba 1 \n");	
    			
    		}
    		pointer=druhe_pole;
    		
    		if((fgets(pointer,10000000,vstup))==NULL) {
    		
    			printf("Chyba 2 \n");	
    		
    		}
    		
    		fclose(vstup);
    	}
       else {
           printf("Chyba pri otevirani souboru\n\a");
    	}
    Váš kód mi fungoval bezproblému, děkuji za něj, bohužel, i když jsem to spravil, nepomohlo to.
    1.12.2011 20:50 johniez | skóre: 17 | blog: xyz | Praha
    Rozbalit Rozbalit vše Re: fopen Segmentation fault C
    Co je pointer?
    1.12.2011 21:12 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: fopen Segmentation fault C
    <joke>¿Obecně, nebo ta proměnná?</joke>
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    1.12.2011 21:10 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: fopen Segmentation fault C
    Bude problém v tom pointer, máte tam rezervováno místo pro 10 000 000 bytů (charů) na to dám krk :-)
    Jen jako ukázka, podle toho co se snažíte:
    #include <stdio.h>
    #include <stdlib.h>
    
    #define MY_SIZE (100000)
    
    //main.cpp
    int main(int argc, char **argv)
    {
      char *pointer = NULL;
      char *prvni_pole = NULL;
      char *druhe_pole = NULL;
      if((prvni_pole = (char*) malloc(sizeof(char) * MY_SIZE)) == NULL)
      {
        printf("Chyba 0-1, nedostatek paměti\n");
        exit(3);
      }
      if((druhe_pole = (char*) malloc(sizeof(char) * MY_SIZE)) == NULL)
      {
        printf("Chyba 0-2, nedostatek paměti\n");
        free(prvni_pole);
        exit(3);
      }
      //aspon
      prvni_pole[0] = druhe_pole[0] = 0x0;
      //nebo cela alokovana pamet:
      //memset(prvni_pole,0x0,MY_SIZE);
      //memset(druhe_pole,0x0,MY_SIZE);
    
      FILE *vstup;
      if ((vstup=fopen("soubor.txt","r")) == NULL) {
        printf("Chyba pri otevirani souboru\n");
        exit(3);
      }
    
      //ukazatel na první pole i když se m;že použít přímo prvni_pole
      pointer = prvni_pole;
    
      if((fgets(pointer,MY_SIZE,vstup))==NULL) {
        printf("Chyba 1 \n");
      }
    
      if(feof(vstup)){
        printf("Chyba uz tam teho vice není\n");
      }
      else
      {
        //ukazatel na druhe pole  i když se může použít přímo druhe_pole
        pointer=druhe_pole;
        if((fgets(pointer,MY_SIZE,vstup))==NULL) {
          printf("Chyba 2 \n");
        }
      }
    
      //obvykle netestuje návratovou hodnotu
      fclose(vstup);
    
      printf("prvni_pole: %s\n",prvni_pole);
      printf("druhe_pole: %s\n",druhe_pole);
    
      //neuskodi
      pointer=NULL;
    
      if(prvni_pole != NULL)//fcil zbytecne
        free(prvni_pole);
      //mozna dobry navyk
      prvni_pole=NULL;
    
      if(druhe_pole != NULL)//fcil zbytecne
        free(druhe_pole);
      //mozna dobry navyk
      druhe_pole=NULL;
    
      return 0;
    }
    
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    2.12.2011 11:09 Mr.S1lent.cz
    Rozbalit Rozbalit vše Re: fopen Segmentation fault C
    Proc proboha alokujes pole dynamicky? Dynamicka alokace je mnohem pomalejsi, nez staticka. Co ti brani v tom, pouzit
    char prvni_pole[MY_SIZE];
    
    ?

    Dynamicke alokaci se snazi clovek co nejvice vyhnout...
    2.12.2011 12:20 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: fopen Segmentation fault C
    Proc proboha alokujes pole dynamicky?
    Protože 20MB (dle původního dotazu) nechci jinak.
    Dynamicka alokace je mnohem pomalejsi, nez staticka.
    Rozdíl rychlosti alokace bude neměřitelný a výsledek možná opačný pokud proměnné budou mimo fci main.
    Co ti brani v tom, pouzit…
    Brání mi rozum a ohled na ostatní.
    Dynamicke alokaci se snazi clovek co nejvice vyhnout...
    Dle této definice nejsem člověk :-) (nebudu se ji vyhýbat za každou cenu), ale vidím to spíše tak, že rozumný programátor použijte to, co je v daném případě lepší a ví kde a jak se, která „rezervace paměti“ provádí…
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    2.12.2011 13:10 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: fopen Segmentation fault C
    Vzhledem k tomu, že v první ukázce bylo MY_SIZE 10^7, nepřipadá mi statická alokace na zásobníku jako dobrý nápad. Pro těch 10^5 by to asi občas i fungovalo, ale stejně je to dost ošklivý zlozvyk.
    2.12.2011 14:05 stepan
    Rozbalit Rozbalit vše Re: fopen Segmentation fault C
    Díky, až budu doma, tak hned ten program vyzkouším. Pak dám vědět, díky zatím všem co pomohli.
    2.12.2011 18:33 stepan
    Rozbalit Rozbalit vše Re: fopen Segmentation fault C
    Díky všem, tuhle diskusi bych chtěl uzavřít. Problém se mi podařilo vyřešit, hlavní problém byl v tom, že jsem staticky alokoval moc velké pole a špatně closnul soubor. Děkuji všem za hodnotné příspěvky, zase jsem o něco zkušenější a snad už příště podobnou chybu neudělám.
    2.12.2011 06:50 Radovan
    Rozbalit Rozbalit vše Re: fopen Segmentation fault C
    A ukazuje ti ten pointer při prvním čtení na prvni_pole?

    Mimochodem, opravdu si cpeš do paměti dvě desetimegabajtová statická pole? :-D
    2.12.2011 13:52 stepan
    Rozbalit Rozbalit vše Re: fopen Segmentation fault C
    Ano, ukazuje. Velikost toho pole je nutná, menší nepřipadá v úvahu.
    2.12.2011 14:16 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: fopen Segmentation fault C
    Pokud ano v 99 % případech, použijete dynamickou alokaci.

    PS: provokativní otázka: „¿Proč?“
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    rADOn avatar 2.12.2011 14:36 rADOn | skóre: 44 | blog: bloK | Praha
    Rozbalit Rozbalit vše Re: fopen Segmentation fault C
    Nevím co s tím chcete provádět, ale hádal bych že je to zralé na mmap()
    "2^24 comments ought to be enough for anyone" -- CmdrTaco
    1.12.2011 19:03 kovariadam | skóre: 12 | blog: biased | Košice/Brno
    Rozbalit Rozbalit vše Re: fopen Segmentation fault C
    p_f = NULL, takze to spadne na fclose(p_f)
    1.12.2011 19:41 stepan
    Rozbalit Rozbalit vše Re: fopen Segmentation fault C
    Aha, tak to já jsem myslel, že i když fopen vrátí hodnotu NULL tak budu muset nějak "odpojit" ten soubor - čili že bude vlastně připojeno "nic".
    frEon avatar 1.12.2011 20:41 frEon | skóre: 40 | Praha
    Rozbalit Rozbalit vše Re: fopen Segmentation fault C
    prave, ze to "nic" se spatne zavira :-) pokud se na to chces koukat takhle...
    Talking about music is like dancing to architecture.
    martin-ux avatar 1.12.2011 21:34 martin-ux | skóre: 18 | Bratislava
    Rozbalit Rozbalit vše Re: fopen Segmentation fault C
    tak, ako ti povedal @kovariadam, zavriet mozes len ten file, ktory bol otvoreny. mozes to dokonca sklbit do jednej podmienky, napr:
            FILE *fp;
    
            if ((fp = fopen("myfile", "r")) == NULL ) {
                    perror("unable to open file");
                    return -1;
            }
            /* praca so suborom a nasledne close */
            fclose(fp);
            return 0;
    
    
    pri uceni je vhodne pouzit aj debugger, napriklad gdb. google ti da vela quick howto ako co .. v tvojom pripadne napriklad:
    
    $ gcc -g -o atest test.c
    $ ./atest
    attempt to close empty null handle
    Segmentation fault: 11 (core dumped)
    $
    
    $ gdb ./atest atest.core
    GNU gdb 6.1.1 [FreeBSD]
    --[snip]--
    
    (gdb) where
    #0  0x0000000800719e37 in fclose () from /lib/libc.so.7
    #1  0x0000000000400686 in main () at test.c:8
    
    (gdb) list 8
    3       int main() {
    4               FILE *p_f = fopen("soubor.txt","r+");
    5
    6               if(p_f == NULL ) {
    7                       fprintf(stderr, "attempt to close empty null handle\n");
    --- vystup z where ->  8                       fclose(p_f);  
    9               }
    10
    11              return 0;
    12      }
    
    
    kde atest je tvoj spustitelny program, core file sa vygeneroval po segfaulte.
    ..when you do things right, people won't be sure you've done anything at all..

    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.