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

    Open source modální textový editor Helix, inspirovaný editory Vim, Neovim či Kakoune, byl vydán ve verzi 25.07. Přehled novinek se záznamy terminálových sezení v asciinema v oznámení na webu. Detailně v CHANGELOGu na GitHubu.

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

    Americký výrobce čipů Nvidia získal od vlády prezidenta Donalda Trumpa souhlas s prodejem svých pokročilých počítačových čipů používaných k vývoji umělé inteligence (AI) H20 do Číny. Prodej těchto čipů speciálně upravených pro čínský trh by tak mohl být brzy obnoven, uvedla firma na svém blogu. Americká vláda zakázala prodej v dubnu, v době eskalace obchodního sporu mezi oběma zeměmi. Tehdy to zdůvodnila obavami, že by čipy mohla využívat čínská armáda.

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

    3D software Blender byl vydán ve verzi 4.5 s prodlouženou podporou. Podrobnosti v poznámkách k vydání. Videopředstavení na YouTube.

    Ladislav Hagara | Komentářů: 0
    14.7. 22:22 | Komunita

    Open source webový aplikační framework Django slaví 20. narozeniny.

    Ladislav Hagara | Komentářů: 0
    14.7. 16:11 | Komunita

    V Brestu dnes začala konference vývojářů a uživatelů linuxové distribuce Debian DebConf25. Na programu je řada zajímavých přednášek. Sledovat je lze online.

    Ladislav Hagara | Komentářů: 0
    14.7. 11:33 | IT novinky

    Před 30 lety, tj. 14. července 1995, se začala používat přípona .mp3 pro soubory s hudbou komprimovanou pomocí MPEG-2 Audio Layer 3.

    Ladislav Hagara | Komentářů: 26
    14.7. 10:55 | IT novinky

    Výroba 8bitových domácích počítačů Commodore 64 byla ukončena v dubnu 1994. Po více než 30 letech byl představen nový oficiální Commodore 64 Ultimate (YouTube). S deskou postavenou na FPGA. Ve 3 edicích v ceně od 299 dolarů a plánovaným dodáním v říjnu a listopadu letošního roku.

    Ladislav Hagara | Komentářů: 20
    13.7. 17:55 | Zajímavý projekt

    Společnost Hugging Face ve spolupráci se společností Pollen Robotics představila open source robota Reachy Mini (YouTube). Předobjednat lze lite verzi za 299 dolarů a wireless verzi s Raspberry Pi 5 za 449 dolarů.

    Ladislav Hagara | Komentářů: 17
    11.7. 16:44 | Komunita

    Dnes v 17:30 bude oficiálně vydána open source počítačová hra DOGWALK vytvořena v 3D softwaru Blender a herním enginu Godot. Release party proběhne na YouTube od 17:00.

    Ladislav Hagara | Komentářů: 3
    11.7. 14:55 | Humor

    McDonald's se spojil se společností Paradox a pracovníky nabírá také pomocí AI řešení s virtuální asistentkou Olivii běžící na webu McHire. Ian Carroll a Sam Curry se na toto AI řešení blíže podívali a opravdu je překvapilo, že se mohli přihlásit pomocí jména 123456 a hesla 123456 a získat přístup k údajům o 64 milionech uchazečů o práci.

    Ladislav Hagara | Komentářů: 16
    Jaký je váš oblíbený skriptovací jazyk?
     (59%)
     (26%)
     (7%)
     (3%)
     (1%)
     (1%)
     (4%)
    Celkem 398 hlasů
     Komentářů: 16, poslední 8.6. 21:05
    Rozcestník

    Dotaz: Zaciatocnicky problem v C

    10.12.2009 23:32 kovariadam | skóre: 12 | blog: biased | Košice/Brno
    Zaciatocnicky problem v C
    Přečteno: 454×
    Dobry den, prosim o radu s nasledujucim problemom: mam funkciu split_string, ktora berie parameter ret ako navratovu hodnotu. Potom naalokuje dvojrozmerne pole. A spravne.

    int split_string (char **ret, char *str, unsigned char del)
    {
    
      ret = (char **) malloc (sizeof (char *) * (count + 1));
    
        ret[i] = (char *) malloc (sizeof (char) * (strlen (back_str) + 1));
    }

    Potom ju volam na tomto mieste:

    char **row_parts = NULL;
    unsigned int parts_count = split_string (row_parts, line, ';');
    

    Tu to ale spadne.

    printf ("%u %s\n", parts_count, row_parts[0]);

    Preco je row_parts[0] nepovoleny pristup do pamati ak ret[0] v split_string je normalne dostupny?

    Prikladam este vystup z debuggera:

    Program received signal EXC_BAD_ACCESS, Could not access memory.
    Reason: KERN_PROTECTION_FAILURE at address: 0x00000000
    parse_row (line=0x400150 "chalupa") at proj4.c:169
    169	    printf ("%u %s\n", parts_count, row_parts[0]);
    (gdb) 
    

    Vopred dakujem za kazdu radu.

    Řešení dotazu:


    Odpovědi

    11.12.2009 00:00 Vojtěch Horký | skóre: 39 | blog: Vojtův zápisník | Praha
    Rozbalit Rozbalit vše Re: Zaciatocnicky problem v C
    Mňo, možná by nebylo od věci dát sem kompletní zdroják, resp. nevykusovat z něj části jako třeba ten for cyklus v split_string, proměnnou back_str atd.
    Reason: KERN_PROTECTION_FAILURE at address: 0x00000000
    Přistupujete na adresu 0, čili derefernce NULL-pointeru. Skoro bych řekl, že tam ty hvězdičky v hlavičce funkce mají být 3 a parametr by se měl předávat jako &row_parts), protože takhle to IMHO nezměníte. Čili bude stále NULL.
    I am always ready to learn although I do not always like to be taught. (W. Churchill)
    11.12.2009 00:13 kovariadam | skóre: 12 | blog: biased | Košice/Brno
    Rozbalit Rozbalit vše Re: Zaciatocnicky problem v C
    Dakujem za radu, nechcem byt nezdvorili, ale cely zdrojak sem dat nemozem. Pridam, ale cast zdrojaku, kde sa ta pamat alokuje:

    int split_string (char ***ret, char *str, unsigned char del)
    {
    ...//tu sa s ret nepracuje
    
      *ret = (char **) malloc (sizeof (char *) * (count + 1));
    
      back_str = str;
    
      for (i = 0; *back_str && i < strlen (str); i++)
      {
        printf ("%u: %ld", i, strlen (back_str));
        *ret[i] = (char *) malloc (sizeof (char) * (strlen (back_str) + 1));

    Povodne som to aj mal s tymi 3 "hviezdickami", ale potom mam chybu vnutri tej split_string.

    Program received signal EXC_BAD_ACCESS, Could not access memory.
    Reason: KERN_PROTECTION_FAILURE at address: 0x00000c00
    0x00002a25 in split_string (ret=0xbffff55c, str=0x400150 "chalupa", del=59 ';') at proj4.c:244
    244	    *ret[i] = (char *) malloc (sizeof (char) * (strlen (back_str) + 1));
    

    To sa mi ale velmi nezda, ten ret by uz mal byt na tom mieste alokovany ako ukazovatel na ukazovatele alebo sa mylim?

    Este pre uplnost, tie ostatne premenne su nastavene spravne, takze by to miesto malo byt naalokovane dobre, sice neosetrujem tam zatial chyby mallocu, ale pamati mam zatial viac nez dost.
    11.12.2009 00:21 Vojtěch Horký | skóre: 39 | blog: Vojtův zápisník | Praha
    Rozbalit Rozbalit vše Re: Zaciatocnicky problem v C
    Dakujem za radu, nechcem byt nezdvorili, ale cely zdrojak sem dat nemozem.
    Taky nechci být nezdvořilý, ale tímhle si dost rapidně snížíte počet lidí, co budou ochotni odpovídat. O to ale nejde.
    Povodne som to aj mal s tymi 3 "hviezdickami", ale potom mam chybu vnutri tej split_string.
    Střelím od boku, protože po půlnoci si s prioritou nejsem úplně jistý - je *ret[i] správně uzávorkované - nemá to být (*ret)[i]?
    I am always ready to learn although I do not always like to be taught. (W. Churchill)
    11.12.2009 00:25 kovariadam | skóre: 12 | blog: biased | Košice/Brno
    Rozbalit Rozbalit vše Re: Zaciatocnicky problem v C
    Dakujem, to bola chyba.
    11.12.2009 17:27 Nikola Pajkovský | skóre: 16
    Rozbalit Rozbalit vše Re: Zaciatocnicky problem v C
    jestli chces rozdelovat retezce podle nejakeho delimitru pouzij funkci "strtok".
    Save the whales. Feed the hungry. Free the mallocs

    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.