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:00 | Bezpečnostní upozornění

    Byly publikovány informace (technické detaily) o bezpečnostním problému Snapu. Jedná se o CVE-2026-3888. Neprivilegovaný lokální uživatel může s využitím snap-confine a systemd-tmpfiles získat práva roota.

    Ladislav Hagara | Komentářů: 2
    dnes 03:33 | Zajímavý software

    Nightingale je open-source karaoke aplikace, která z jakékoliv písničky lokálního alba (včetně videí) dokáže oddělit vokály, získat text a vše přehrát se synchronizací na úrovni jednotlivých slov a hodnocením intonace. Pro separaci vokálů využívá UVR Karaoke model s Demucs od Mety, texty písní stahuje z lrclib.net (LRCLIB), případně extrahuje pomocí whisperX, který rovněž využívá k načasování slov. V případě audiosouborů aplikace na

    … více »
    NUKE GAZA! 🎆 | Komentářů: 1
    včera 18:22 | Nová verze

    Po půl roce vývoje od vydání verze 49 bylo vydáno GNOME 50 s kódovým názvem Tokyo (Mastodon). Podrobný přehled novinek i s náhledy v poznámkách k vydání a v novinkách pro vývojáře.

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

    Článek na stránkách Fedora Magazinu informuje o vydání Fedora Asahi Remixu 43, tj. linuxové distribuce pro Apple Silicon vycházející z Fedora Linuxu 43.

    Ladislav Hagara | Komentářů: 0
    včera 13:33 | Pozvánky

    Byl zveřejněn program konference Installfest 2026. Konference proběhne o víkendu 28. a 29. března v Praze na Karlově náměstí 13. Vstup zdarma.

    Ladislav Hagara | Komentářů: 3
    včera 03:55 | Nová verze

    Byla vydána Java 26 / JDK 26. Nových vlastností (JEP - JDK Enhancement Proposal) je 10. Odstraněno bylo Applet API.

    Ladislav Hagara | Komentářů: 10
    17.3. 23:55 | Nová verze

    Byla vydána nová verze 260 správce systému a služeb systemd (Wikipedie, GitHub). Odstraněna byla podpora skriptů System V. Aktualizovány byly závislosti. Minimální verze Linuxu z 5.4 na 5.10, OpenSSL z 1.1.0 na 3.0.0, Pythonu z 3.7.0 na 3.9.0…

    Ladislav Hagara | Komentářů: 23
    17.3. 18:11 | Nová verze

    Byla vydána nová verze 5.1 svobodného 3D softwaru Blender. Přehled novinek i s náhledy a videi v poznámkách k vydání. Videopředstavení na YouTube.

    Ladislav Hagara | Komentářů: 0
    17.3. 04:55 | Nová verze

    Bylo oznámeno vydání nové verze 8.1 "Hoare" kolekce svobodného softwaru umožňujícího nahrávání, konverzi a streamovaní digitálního zvuku a obrazu FFmpeg (Wikipedie). Doprovodný příspěvek na blogu Khronosu rozebírá kódování a dekódování videa pomocí Vulkan Compute Shaders v FFmpeg.

    Ladislav Hagara | Komentářů: 12
    17.3. 04:33 | Zajímavý projekt

    Byl představen open-source a open-hardware prototyp nízkonákladového raketometu kategorie MANPADS, který byl sestaven z běžně dostupné elektroniky a komponent vytištěných na 3D tiskárně. Raketa využívá skládací stabilizační křidélka a canardovou stabilizaci aktivně řízenou palubním letovým počítačem ESP32, vybaveným inerciální měřicí jednotkou MPU6050 (gyroskop a akcelerometr). Přenosné odpalovací zařízení obsahuje GPS,

    … více »
    NUKE GAZA! 🎆 | Komentářů: 49
    Které desktopové prostředí na Linuxu používáte?
     (16%)
     (7%)
     (1%)
     (11%)
     (29%)
     (2%)
     (5%)
     (1%)
     (13%)
     (24%)
    Celkem 1110 hlasů
     Komentářů: 27, poslední 17.3. 19:26
    Rozcestník

    Dotaz: pomoc s ladenim kodu v C

    17.8.2009 17:37 ext3fs
    pomoc s ladenim kodu v C
    Přečteno: 323×

    Dobry den,

     chci poprosit s pomoci nalezeni chyby v nasledujicim kodu:

    (komentuji radky kde valgrind hlasi chybu).

    char *get_term(char *str, int pos)                                              
    {                                                                               
    int n;                                                                          
    int word = 0;                                                                   
    int w = 0, w_m = 0;                                                             
    short in_word = 0;                                                              
    short out_word = 0;                                                             
    char **words;                                                                   

        for(n = 0; str[n] != '\0'; n++)                            
        {                                                          
                    if (str[n] == '<' || str[n] == ' ' || str[n] == '>')
                    {                                                   
                    if (in_word)                                        
                    {                                                   
                                    if (w > w_m)                        
                                    w_m = w;                            
                    }                                                   
                    out_word = 1;                                       
                    in_word = 0;                                        
                    w = 0;                                              
                    }                                                   
                    else if (!in_word)                                  
                    {                                                   
                    word++;                                             
                    out_word = 0;                                       
                    in_word = 1;                                        
                    }                                                   
                    if (in_word)                                        
                    w++;                                                
        }                                                               

    /*ZDE*/    if ((words = (char **)malloc(word*(sizeof(char *)))) == NULL)
            {                                                        
                    fprintf(stderr, "chps : %s\n", strerror(errno));
                    exit (1);                                        
            }                                                        
                                                                     
        for (n = 0; n < word; n++)                                   
            {                                                        
                    if ((words[n] = (char *)malloc(w_m*sizeof(char))) == NULL)
                    {                                                         
                            fprintf(stderr, "chps : %s\n", strerror(errno));  
                            exit (1);                                         
                    }                                                         
            }                                                                 

        in_word = out_word = 0;
        w = w_m = word = 0;    
        for(n = 0; str[n] != '\0'; n++)
        {
                    if (str[n] == '<' || str[n] == ' ' || str[n] == '>')
                    {
                    if (in_word)
                    {
                                    if (w > w_m)
                                    {
                                    w_m = w;
                                    }
                                    /*ZDE*/ words[word - 1][w] = '\0';
                    }
                    out_word = 1;
                    in_word = 0;
                    w = 0;
                    }
                    else if (!in_word)
                    {
                    word++;
                    out_word = 0;
                    in_word = 1;
                    }
                    if (in_word)
                    words[word - 1][w++] = str[n];
        }

        if (pos <= word)
                    return(words[pos - 1]);
        else
                    return(" ");
    }

    Funkce se vola napr get_term("<NAME opt1 opt2 opt3>", 2); a

    vrati opt1.

     

    Dekuji.

    Odpovědi

    17.8.2009 19:12 pht | skóre: 48 | blog: pht
    Rozbalit Rozbalit vše Re: pomoc s ladenim kodu v C
    když to chcípe na malloc, tak jste pravděpodobně poškodil haldu zapsáním mimo meze polí. při pohledu na kód se nedivím... není to trochu moc práce kvůli takové blbosti?
    
    #include <string.h>
    #include <stdio.h>
    #include <stdlib.h>
    
    char *get_term(const char *str, int pos)
    {
            char *p, *q, *r;
            size_t len;
    
            if ((pos < 1) || !str) {
                    return NULL;
            }
            len = strlen(str);
            if ((*str != '<') || (str[len - 1] != '>')) {
                    return NULL;
            }
    
            p = (char *)str + 1;
            while (--pos) {
                    p = strchr(p, ' ');
                    if (!p || !*p) {
                            return NULL;
                    }
                    p++;
            }
            q = strchr(p, ' ');
            if (!q) {
                    q = (char *)str + len - 2;
            }
            if (p > q) {
                    return NULL;
            }
            r = malloc(q - p + 2);
            if (!r) {
                    return NULL;
            }
            memcpy(r, p, q - p + 1);
            r[q - p + 1] = '\0';
            return r;
    }
    
    int main()
    {
            const char *s = "<a b c d>";
            int i;
    
            for (i = 1; i <= 5; i++) {
                    char *p = get_term(s, i);
    
                    printf("%d: %s\n", i, p ? p : "not found");
                    if (p) {
                            free(p);
                    }
            }
            return 0;
    }
    
    
    In Ada the typical infinite loop would normally be terminated by detonation.
    17.8.2009 20:34 ext3fs
    Rozbalit Rozbalit vše Re: pomoc s ladenim kodu v C

    Dekuji za spravne nakopnuti. Kod jsem smazal a napsal znovu na polovinu radku a uz to funguje.

    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.