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 18:22 | Komunita

    V kinech aktuálně běží animovaný film Kočičí odysea, v originálu Flow, (Wikipedie) vytvořený v Blenderu. Film získal řadu ocenění a má dvě nominace na Oscary 2025. Na ČSFD má 80 %. Režisérem je Gints Zilbalodis. Rozhovor s režisérem na stránkách Blenderu.

    Ladislav Hagara | Komentářů: 0
    dnes 17:33 | Nová verze

    Oficiálně byla vydána (Mastodon, 𝕏) třetí RC verze GIMPu 3.0. Přehled novinek v oznámení o vydání. Podrobně v souboru NEWS na GitLabu. GIMP je nově k dispozici také ve formátu AppImage.

    Ladislav Hagara | Komentářů: 6
    dnes 14:44 | Zajímavý projekt

    Nejnovějším projektem Blender Studia je herní projekt DogWalk. Cílem projektu je prozkoumat možnosti a vylepšit spolupráci Blenderu s herním enginem Godot a vytvořit jednoduchou hru. Jde o jejich druhý herní projekt. Prvním byla hra Yo Frankie! (projekt Apricot) postavená na již nevyvíjeném Blender Game Enginu.

    Ladislav Hagara | Komentářů: 0
    dnes 11:22 | Nová verze

    Byla vydána verze 0.83 telnet a ssh klienta PuTTY. Podrobnosti v přehledu nových vlastností a oprav chyb a Change Logu. Vypíchnuta je podpora výměny klíčů pomocí postkvantového algoritmus ML-KEM.

    Ladislav Hagara | Komentářů: 0
    včera 16:33 | Komunita

    Hector "marcan" Martin z Asahi Linuxu skončil jako upstream vývojář linuxového jádra. Štafetu po něm převzal Janne Grunau z Asahi Linuxu.

    Ladislav Hagara | Komentářů: 15
    8.2. 22:33 | IT novinky

    PlayStation Network (PSN) má již několik hodin, vlastně celou sobotu, masivní výpadek (Stav služby PSN, X).

    Ladislav Hagara | Komentářů: 1
    8.2. 17:22 | Komunita

    Vývojáři open source storage platformy TrueNAS oznámili, že s verzí 25.04 s kódovým názvem Fangtooth končí TrueNAS CORE postavený na FreeBSD a TrueNAS SCALE postavený na Linuxu. Jejich společným pokračováním bude TrueNAS Community Edition postavený na Linuxu.

    Ladislav Hagara | Komentářů: 15
    8.2. 15:55 | IT novinky

    Mapy Google dnes slaví 20 let. Spuštěny byly 8. února 2005. Svět se přesunul od papírových map k digitálním. A ke Street View, Live View, Immersive View, …

    Ladislav Hagara | Komentářů: 48
    8.2. 02:55 | Komunita

    Hector "marcan" Martin, vedoucí projektu Asahi Linux aneb Linux na Apple Siliconu, skončil jako upstream vývojář linuxového jádra. Se slovy "už nemám žádnou důvěru v proces vývoje jádra … další vývoj Apple/ARM bude pokračovat downstream" odstranil své jméno ze souboru MAINTAINERS. Důvodem jsou neshody kolem Rustu v linuxovém jádru [Hacker News, No rust code in kernel/dma, please.].

    Ladislav Hagara | Komentářů: 100
    7.2. 16:55 | IT novinky

    Mistral AI včera představil nový vylepšený Le Chat. Nově také jako aplikace pro iOS a Android.

    Ladislav Hagara | Komentářů: 3
    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: 448×
    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.