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 16:11 | Nová verze

    Byl vydán Mozilla Firefox 152.0. Přehled novinek v poznámkách k vydání a poznámkách k vydání pro vývojáře. Řešeny jsou rovněž bezpečnostní chyby. Nový Firefox 152 bude brzy k dispozici také na Flathubu a Snapcraftu.

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

    Desktopové prostředí KDE Plasma bylo vydáno ve verzi 6.7 (Mastodon). Přehled novinek i s videi a se snímky obrazovek v oficiálním oznámení. Podrobný přehled v seznamu změn.

    Ladislav Hagara | Komentářů: 4
    dnes 11:44 | Komunita

    Hříčka xsnow, která na ploše spustí sněžení, je protestware. Pokud jste v Rusku (LANG=ru), zobrazuje ukrajinské vlajky.

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

    UBports, nadace a komunita kolem Ubuntu pro telefony a tablety Ubuntu Touch, vydala beta verzi Ubuntu Touch 24.04-2.0. Nová verze již počítá s výřezy pro fotoaparát (notch) a zaoblenými rohy displeje. Webový prohlížeče Morph přešel z Chromia 87 na Chromium 134. Do shellu Lomiri byl přidán editor snímků obrazovky.

    Ladislav Hagara | Komentářů: 0
    dnes 04:22 | Komunita

    V Praze probíhá Flock 2026, tj. konference pro přispěvatele a příznivce Fedory. Přednášky lze sledovat také na YouTube.

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

    Node-RED (Wikipedie, GitHub), webová aplikace postavená na Node.js pro vizuální programování a propojování hardwarových zařízení, API a online služeb, byl vydán ve verzi 5.0. Přehled novinek v příspěvku na blogu.

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

    Byla vydána nová verze 3.27.0 FreeRDP, tj. svobodné implementace protokolu RDP (Remote Desktop Protocol). Opraveno bylo 5 zranitelností.

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

    Řídící výbor GCC schválil záměr do GCC začlenit backend WebAssembly.

    Ladislav Hagara | Komentářů: 2
    14.6. 21:00 | Nová verze

    Po 9 týdnech vývoje od vydání Linuxu 7.0 oznámil Linus Torvalds vydání Linuxu 7.1. Přehled novinek a vylepšení na LWN.net: první a druhá polovina začleňovacího okna a časem také na Linux Kernel Newbies.

    Ladislav Hagara | Komentářů: 0
    14.6. 13:33 | Zajímavý software

    Cheat Engine (Wikipedie) je s verzí 7.7 k dispozici už také pro Linux. Jedná se o proprietární skener/debugger paměti používaný především k cheatování v počítačových hrách.

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (11%)
     (8%)
     (2%)
     (16%)
     (31%)
     (3%)
     (6%)
     (3%)
     (15%)
     (26%)
    Celkem 1918 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: 634×
    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.