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 13:33 | Komunita

    Software Freedom Conservancy v novém dokumentu shrnuje doporučení, jak přistupovat ke generativní AI založené na LLM při přispívání do svobodného a open-source softwaru. Mimo jiné vyzývá k obezřetnosti, transparentnosti a revizi generovaného kódu člověkem.

    |🇵🇸 | Komentářů: 0
    dnes 13:22 | Nová verze

    Byla vydána nová verze 5.6.0 programu na úpravu digitálních fotografií darktable (Wikipedie).

    Ladislav Hagara | Komentářů: 0
    včera 20:11 | Komunita

    Na čem aktuálně pracují vývojáři GNOME a KDE Plasma? Pravidelný přehled novinek v Týden v GNOME a Týden v KDE Plasma. V Týdnu v GNOME je zmíněn flatpak balíček pro GIMP 0.54.1 z roku 1996. Jedná se o poslední verzi GIMPu postavenou nad toolkitem Motif.

    Ladislav Hagara | Komentářů: 0
    včera 19:11 | Nová verze

    Home Assistant Operating System, tj. linuxová distribuce optimalizována pro hostování Home Assistanta a jeho aplikací, byl vydán v nové major verzi 18.0.

    Ladislav Hagara | Komentářů: 0
    včera 18:11 | Komunita

    Po šestiletém úsilí byla z jádra Linux odstraněna funkce strncpy(). Všechna předchozí volání této funkce byla převedena na bezpečnější alternativy.

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

    Byla vydána nová verze 261 správce systému a služeb systemd (Wikipedie, GitHub). Z novinek lze vypíchnout nový subsystém IMDS (Cloud "Instance Metadata Service"), nový příkaz storagectl nebo novou komponentu systemd-sysinstall.

    Ladislav Hagara | Komentářů: 3
    včera 12:00 | Nová verze

    Vývojové prostředí Qt Creator bylo vydáno ve verzi 20 (seznam změn). Novinky zahrnují hlavně rozšíření pro integraci LLM agentů nebo minimalistický editační režim uživatelského rozhraní („zen mode“).

    |🇵🇸 | Komentářů: 0
    19.6. 10:22 | Humor

    Už jste se prolétli na webu Google Earth? Přibyl tam Simulátor letu (Nástroje / Simulátor letu). Funguje i bez účtu Google [𝕏].

    Ladislav Hagara | Komentářů: 0
    19.6. 09:55 | Nová verze

    Byla vydána nová verze 4.7 (𝕏, Bluesky, Mastodon) multiplatformního open source herního enginu Godot (Wikipedie, GitHub). Přehled novinek i s náhledy v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 3
    18.6. 13:33 | Nová verze

    Mastodon (Wikipedie) - sociální síť, která není na prodej - byl vydán ve verzi 4.6. Přehled novinek s náhledy v oznámení na blogu.

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (11%)
     (8%)
     (2%)
     (16%)
     (31%)
     (3%)
     (6%)
     (3%)
     (15%)
     (26%)
    Celkem 1953 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    Rozcestník


    Dotaz: Pole v C

    23.11.2008 09:05 pole
    Pole v C
    Přečteno: 642×
    Dobrej den, nejsem moc skuseny programator, prave zacinam programovat v C. Naprogramoval jsem si program, ale dava mi nejakou chybu Segmentation fault.

    int N, i, *p_i;

    p_i= (int *) malloc(N * sizeof(int));

    scanf("%d", &N);

    for (i=0; i < N; i++){

    scanf("%d", p_i+i);

    printf("\n%d\n", *(p_i+i));

    }

    Tohle je cast kodu. Pamet se alokuje sparvne, delal sem test na NULL. Nevite kde by mohl byt problem? Program spravne uklada hodnoty do pola, ale v momente kdy by mnel cyklus opustit vypise Segmentation fault a program ukonci. Dik moc

    Odpovědi

    23.11.2008 09:28 finn | skóre: 43 | blog: finnlandia | 49° 44´/13° 22´
    Rozbalit Rozbalit vše Re: Pole v C
    Alokuješ paměť pro pole ještě než se dozvíš jeho velikost (N).
    Užívej dne – možná je tvůj poslední.
    23.11.2008 09:38 pole
    Rozbalit Rozbalit vše Re: Pole v C
    Spatne jsem prepsal kod. Samozrejme alokuji az po zjisteni N.
    23.11.2008 10:29 finn | skóre: 43 | blog: finnlandia | 49° 44´/13° 22´
    Rozbalit Rozbalit vše Re: Pole v C
    Tohle u mne žádný SIGSEGV nevyvolá:
    #include <stdio.h>
    #include <stdlib.h>
    
    int main(void)
    {
      int N, i, *p_i;
    
      scanf("%d", &N);
      p_i = (int *) malloc(N * sizeof(int));
    
      for(i = 0; i < N; i++)
      {
        scanf("%d", p_i + i);
        printf("\n%d\n", *(p_i + i));
      }
    
      return 0;
    }
    
    
    Užívej dne – možná je tvůj poslední.
    23.11.2008 11:13 pole
    Rozbalit Rozbalit vše Re: Pole v C

    Nechapu to.

    Ja jsem skompiloval jeste jednou a ted to funguje. Ak vsak skompiluju znovu, tak to nejede a pak zas jede. Kompiloval jsem presne tento kod.

    Takze se to uz z casti vyresilo. Ale proc raz jede, raz ne ?

    Dekuji

    David Watzke avatar 23.11.2008 11:41 David Watzke | skóre: 74 | blog: Blog... | Praha
    Rozbalit Rozbalit vše Re: Pole v C
    Možná HW problém... paměti jsou ok, nic jinýho nezlobí?
    “Being honest may not get you a lot of friends but it’ll always get you the right ones” ―John Lennon
    23.11.2008 10:29 Boris Dušek | skóre: 22 | blog: everything
    Rozbalit Rozbalit vše Re: Pole v C

     

    Spatne jsem prepsal kod.

     

    s g++ i Visual C++ to nepadá - možná by bylo lepší poslat větší část originálního kódu? Taky by se hodilo znát přesné hodnoty, na kterých to padá (když na "všech", tak aspoň jeden příklad - určitě si netestoval všechny možné vstupy, těch je nekonečně mnoho).

    vim ~/.emacs
    23.11.2008 12:05 kvé
    Rozbalit Rozbalit vše Re: Pole v C
    Podivejte se pres gdb nebo valgrind, kde a kvuli cemu to padne.
    23.11.2008 17:31 trekker.dk | skóre: 72
    Rozbalit Rozbalit vše Re: Pole v C
    Nebo jednodušeji:

    printf ("Zadej počet prvků: ");, printf ("Zadej %i. prvek: ", i);
    Quando omni flunkus moritati
    23.11.2008 18:28 kvé
    Rozbalit Rozbalit vše Re: Pole v C
    Nerekl bych, ta chyba muze byt zpusobena spatnym zapisem do pameti z upne jineho mista programu.
    23.11.2008 19:21 trekker.dk | skóre: 72
    Rozbalit Rozbalit vše Re: Pole v C
    a) Stejně to bude vypadat líp, když ten program vypíše, co chce, místo aby jenom čekal, až zahřmí

    b) Pokud je chyba opravdu v tomto kódu, bude to jednodušší než zjišťovat, jak funguje valgrind a gdb.
    Quando omni flunkus moritati
    24.11.2008 12:09 kvé
    Rozbalit Rozbalit vše Re: Pole v C
    Tento kod je ale spravne, proto mu to bude k nicemu.
    25.11.2008 00:25 trekker.dk | skóre: 72
    Rozbalit Rozbalit vše Re: Pole v C
    Viz bod a)
    Quando omni flunkus moritati

    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.