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í
×
    včera 18:44 | Komunita

    Od soboty do úterý probíhá v Hamburku konference 39C3 (Chaos Communication Congress) věnovaná také počítačové bezpečnosti nebo hardwaru. Program (jiná verze) slibuje řadu zajímavých přednášek. Streamy a záznamy budou k dispozici na media.ccc.de.

    Ladislav Hagara | Komentářů: 0
    včera 13:22 | Zajímavý software

    Byl představen nový Xserver Phoenix, kompletně od nuly vyvíjený v programovacím jazyce Zig. Projekt Phoenix si klade za cíl být moderní alternativou k X.Org serveru.

    🇨🇽 | Komentářů: 1
    včera 13:11 | Nová verze

    XLibre Xserver byl 21. prosince vydán ve verzi 25.1.0, 'winter solstice release'. Od založení tohoto forku X.Org serveru se jedná o vůbec první novou minor verzi (inkrementovalo se to druhé číslo v číselném kódu verze).

    🇨🇽 | Komentářů: 0
    včera 03:33 | Nová verze

    Wayback byl vydán ve verzi 0.3. Wayback je "tak akorát Waylandu, aby fungoval Xwayland". Jedná se o kompatibilní vrstvu umožňující běh plnohodnotných X11 desktopových prostředí s využitím komponent z Waylandu. Cílem je nakonec nahradit klasický server X.Org, a tím snížit zátěž údržby aplikací X11.

    Ladislav Hagara | Komentářů: 0
    25.12. 14:44 | Nová verze

    Byla vydána verze 4.0.0 programovacího jazyka Ruby (Wikipedie). S Ruby Box a ZJIT. Ruby lze vyzkoušet na webové stránce TryRuby. U příležitosti 30. narozenin, první veřejná verze Ruby 0.95 byla oznámena 21. prosince 1995, proběhl redesign webových stránek.

    Ladislav Hagara | Komentářů: 0
    24.12. 02:11 | Komunita

    Všem čtenářkám a čtenářům AbcLinuxu krásné Vánoce.

    Ladislav Hagara | Komentářů: 27
    24.12. 02:00 | Nová verze

    Byla vydána nová verze 7.0 linuxové distribuce Parrot OS (Wikipedie). S kódovým názvem Echo. Jedná se o linuxovou distribuci založenou na Debianu a zaměřenou na penetrační testování, digitální forenzní analýzu, reverzní inženýrství, hacking, anonymitu nebo kryptografii. Přehled novinek v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 0
    23.12. 18:33 | Nová verze

    Vývojáři postmarketOS vydali verzi 25.12 tohoto před osmi lety představeného operačního systému pro chytré telefony vycházejícího z optimalizovaného a nakonfigurovaného Alpine Linuxu s vlastními balíčky. Přehled novinek v příspěvku na blogu. Na výběr jsou 4 uživatelská rozhraní: GNOME Shell on Mobile, KDE Plasma Mobile, Phosh a Sxmo.

    Ladislav Hagara | Komentářů: 0
    23.12. 13:55 | Nová verze

    Byla vydána nová verze 0.41.0 multimediálního přehrávače mpv (Wikipedie) vycházejícího z přehrávačů MPlayer a mplayer2. Přehled novinek, změn a oprav na GitHubu. Požadován je FFmpeg 6.1 nebo novější a také libplacebo 6.338.2 nebo novější.

    Ladislav Hagara | Komentářů: 0
    23.12. 12:44 | Nová verze

    Byla vydána nová verze 5.5 (novinky) skriptovacího jazyka Lua (Wikipedie). Po pěti a půl letech od vydání verze 5.4.

    Ladislav Hagara | Komentářů: 0
    Kdo vám letos nadělí dárek?
     (34%)
     (2%)
     (14%)
     (2%)
     (2%)
     (2%)
     (16%)
     (17%)
     (11%)
    Celkem 106 hlasů
     Komentářů: 18, poslední 24.12. 15:29
    Rozcestník

    Dotaz: pomoc s ladenim kodu v C

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

    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.