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 17:11 | IT novinky

    Společnost Jolla spustila kampaň na podporu svého nového telefonu Jolla Phone se Sailfish OS. Dodání je plánováno na první polovinu příštího roku. Pokud bude alespoň 2 000 zájemců. Záloha na telefon je 99 €. Cena telefonu v rámci kampaně je 499 €.

    Ladislav Hagara | Komentářů: 9
    dnes 15:11 | IT novinky

    Netflix kupuje Warner Bros. včetně jejích filmových a televizních studií HBO Max a HBO. Za 72 miliard dolarů (asi 1,5 bilionu korun).

    Ladislav Hagara | Komentářů: 1
    dnes 14:11 | IT novinky

    V Las Vegas dnes končí pětidenní konference AWS re:Invent 2025. Společnost Amazon Web Services (AWS) na ní představila celou řadu novinek. Vypíchnout lze 192jádrový CPU Graviton5 nebo AI chip Trainium3.

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

    Firma Proxmox vydala novou serverovou distribuci Datacenter Manager ve verzi 1.0 (poznámky k vydání). Podobně jako Virtual Environment, Mail Gateway či Backup Server je založená na Debianu, k němuž přidává integraci ZFS, webové administrační rozhraní a další. Datacenter Manager je určený ke správě instalací právě ostatních distribucí Proxmox.

    |🇵🇸 | Komentářů: 6
    včera 23:44 | Nová verze

    Byla vydána nová verze 2.4.66 svobodného multiplatformního webového serveru Apache (httpd). Řešeno je mimo jiné 5 bezpečnostních chyb.

    Ladislav Hagara | Komentářů: 0
    včera 14:00 | IT novinky

    Programovací jazyk JavaScript (Wikipedie) dnes slaví 30 let od svého oficiálního představení 4. prosince 1995.

    Ladislav Hagara | Komentářů: 0
    včera 04:22 | Bezpečnostní upozornění

    Byly zveřejněny informace o kritické zranitelnosti CVE-2025-55182 s CVSS 10.0 v React Server Components. Zranitelnost je opravena v Reactu 19.0.1, 19.1.2 a 19.2.1.

    Ladislav Hagara | Komentářů: 3
    včera 02:44 | Komunita

    Bylo rozhodnuto, že nejnovější Linux 6.18 je jádrem s prodlouženou upstream podporou (LTS). Ta je aktuálně plánována do prosince 2027. LTS jader je aktuálně šest: 5.10, 5.15, 6.1, 6.6, 6.12 a 6.18.

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

    Byla vydána nová stabilní verze 3.23.0, tj. první z nové řady 3.23, minimalistické linuxové distribuce zaměřené na bezpečnost Alpine Linux (Wikipedie) postavené na standardní knihovně jazyka C musl libc a BusyBoxu. Přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 1
    3.12. 18:11 | Nová verze

    Byla vydána verze 6.0 webového aplikačního frameworku napsaného v Pythonu Django (Wikipedie). Přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    Jaké řešení používáte k vývoji / práci?
     (34%)
     (47%)
     (19%)
     (18%)
     (23%)
     (15%)
     (25%)
     (16%)
     (18%)
    Celkem 431 hlasů
     Komentářů: 18, poslední 2.12. 18:34
    Rozcestník

    Dotaz: pomoc s ladenim kodu v C

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

    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.