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

    Linus Torvalds vydal jádro Linux 6.19. Podrobný výčet změn je ke zhlédnutí na stránce Kernel Newbies, stručné výběry v LWN (část první, druhá).

    |🇵🇸 | Komentářů: 0
    včera 03:33 | IT novinky

    Do prodeje jde tichá bezdrátová herní myš Logitech PRO X2 SUPERSTRIKE s analogovými spínači s haptickou odezvou (HITS, Haptic Inductive Trigger System). Cena je 4 459 Kč.

    Ladislav Hagara | Komentářů: 5
    7.2. 21:00 | Zajímavý projekt

    Microsoft na GitHubu zveřejnil zdrojový kód projektu LiteBox, jedná se o 'knihovní operační systém' (library OS) zaměřený na bezpečnost, využívající systémovou architekturu LVBS k ochraně jádra před útoky z uživatelského prostoru. LiteBox je napsán v Rustu a uvolněný pod licencí MIT. Projekt je teprve v rané fázi vývoje.

    NUKE GAZA! 🎆 | Komentářů: 1
    7.2. 16:11 | Zajímavý software

    BreezyBox je open-source shell a virtuální terminál pro populární jednočip ESP32. Nabízí základní unixové příkazy, sledování aktuálního pracovního adresáře (CWD), jednoduchý instalátor a spouštěč aplikací v podobě ELF binárních souborů, zabudovaný HTTP server nebo třeba ovládání WiFi - ukázka použití coby 'malého osobního počítače'. Ačkoliv je BreezyBox inspirovaný BusyBoxem, oproti němu má tento projekt několik externích závislostí, zejména na ESP-IDF SDK. BreezyBox je dostupný pod licencí MIT.

    NUKE GAZA! 🎆 | Komentářů: 0
    7.2. 16:00 | Humor

    Byl představen cross-assembler xa.sh, napsaný čistě v Bourne shell skriptu. Tento nástroj umožňuje zpracovávat assemblerový kód pro Intel 8080, přičemž je možné snadno přidat podporu i pro další architektury, například 6502 a 6809. Skript využívá pouze různé běžné unixové příkazy jako jsou awk, sed nebo printf. Skript si lze stáhnout z GitHubového repozitáře projektu.

    NUKE GAZA! 🎆 | Komentářů: 6
    6.2. 17:22 | IT novinky

    Byla představena nová verze modelu Claude Opus 4.6 od společnosti Anthropic. Jako demonstraci možností Anthropic využil 16 agentů Claude Opus 4.6 k vytvoření kompilátoru jazyka C, napsaného v programovacím jazyce Rust. Claude pracoval téměř autonomně, projekt trval zhruba dva týdny a náklady činily přibližně 20 000 dolarů. Výsledkem je fungující kompilátor o 100 000 řádcích kódu, jehož zdrojový kód je volně dostupný na GitHubu pod licencí Creative Commons.

    NUKE GAZA! 🎆 | Komentářů: 18
    6.2. 16:44 | Komunita

    Kultovní britský seriál The IT Crowd (Ajťáci) oslavil dvacáté výročí svého prvního vysílání. Sitcom o dvou sociálně nemotorných pracovnících a jejich nadřízené zaujal diváky svým humorem a ikonickými hláškami. Seriál, který debutoval v roce 2006, si i po dvou dekádách udržuje silnou fanouškovskou základnu a pravidelně se objevuje v seznamech nejlepších komedií své doby. Nedávné zatčení autora seriálu Grahama Linehana za hatecrime však vyvolává otázku, jestli by tento sitcom v současné Velké Británii vůbec vznikl.

    NUKE GAZA! 🎆 | Komentářů: 10
    6.2. 13:33 | IT novinky

    Společnost JetBrains oznámila, že počínaje verzí 2026.1 budou IDE založená na IntelliJ ve výchozím nastavení používat Wayland.

    Ladislav Hagara | Komentářů: 4
    6.2. 11:22 | IT novinky

    Společnost SpaceX amerického miliardáře Elona Muska podala žádost o vypuštění jednoho milionu satelitů na oběžnou dráhu kolem Země, odkud by pomohly zajistit provoz umělé inteligence (AI) a zároveň šetřily pozemské zdroje. Zatím se ale neví, kdy by se tak mělo stát. V žádosti Federální komisi pro spoje (FCC) se píše, že orbitální datová centra jsou nejúspornějším a energeticky nejúčinnějším způsobem, jak uspokojit rostoucí poptávku po

    … více »
    Ladislav Hagara | Komentářů: 28
    6.2. 11:11 | Nová verze

    Byla vydána nová verze 2.53.0 distribuovaného systému správy verzí Git. Přispělo 70 vývojářů, z toho 21 nových. Přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (19%)
     (6%)
     (0%)
     (10%)
     (26%)
     (3%)
     (4%)
     (2%)
     (12%)
     (29%)
    Celkem 813 hlasů
     Komentářů: 25, poslední 3.2. 19:50
    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.