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 12:55 | IT novinky

    Protokol IPv6 má již 30 let. První návrh specifikace RFC 1883 je z prosince 1995.

    Ladislav Hagara | Komentářů: 2
    dnes 01:55 | IT novinky

    Byli vyhlášeni vítězové ocenění Steam Awards 2025. Hrou roku a současně nejlepší hrou, která vám nejde, je Hollow Knight: Silksong.

    Ladislav Hagara | Komentářů: 2
    včera 21:11 | Nová verze

    Byla vydána nová verze 26.0 linuxové distribuce Manjaro (Wikipedie). Její kódové jméno je Anh-Linh. Ke stažení je v edicích GNOME, KDE PLASMA a XFCE.

    Ladislav Hagara | Komentářů: 0
    3.1. 20:22 | Humor Ladislav Hagara | Komentářů: 32
    3.1. 19:11 | Zajímavý software

    Byl představen webový prohlížeč Brow6el, běžící v terminálu. Pro prohlížení webu je využit Chromium Embedded Framework, vyrendrovaná webová stránka je následně zobrazena v terminálu převodem na sixely pomocí knihovny libsixel. Brow6el se ovládá modálním klávesnicovým rozhraním, inspirovaném populárním textovým editorem Vim. Demonstrační video s ukázkou používání.

    NUKE GAZA! 🎆 | Komentářů: 5
    2.1. 23:00 | IT novinky

    Společnost Pebble představila (YouTube) chytré hodinky Pebble Round 2. S kulatým e-paper displejem, s open source PebbleOS a vydrží baterie přibližně dva týdny. Předobjednat je lze za 199 dolarů s plánovaným dodáním v květnu.

    Ladislav Hagara | Komentářů: 7
    2.1. 14:22 | Humor

    Na novoroční inauguraci starosty New Yorku Zohrana Mamdaniho bylo zakázáno si s sebou přinést Raspberry Pi anebo Flipper Zero. Raspberry Pi i Flipper Zero jsou explicitně uvedeny v seznamu zakázaných věcí jak na na veřejné pozvánce, tak i na oficiálních stránkách města.

    NUKE GAZA! 🎆 | Komentářů: 61
    2.1. 11:33 | Nová verze

    OpenTTD (Wikipedie), tj. open source klon počítačové hry Transport Tycoon Deluxe, byl vydán v nové stabilní verzi 15.0. Přehled novinek v seznamu změn a také na YouTube. OpenTTD lze instalovat také ze Steamu.

    Ladislav Hagara | Komentářů: 5
    2.1. 11:11 | Nová verze

    Správce oken IceWM byl vydán ve verzi 4.0.0, která např. vylepšuje navigaci v přepínání velkého množství otevřených oken.

    |🇵🇸 | Komentářů: 5
    2.1. 01:33 | Zajímavý projekt

    Od 1. ledna 2026 jsou všechny publikace ACM (Association for Computing Machinery) a související materiály přístupné v její digitální knihovně. V rámci této změny je nyní digitální knihovna ACM nabízena ve dvou verzích: v základní verzi zdarma, která poskytuje otevřený přístup ke všem publikovaným výzkumům ACM, a v prémiové zpoplatněné verzi, která nabízí další služby a nástroje 'určené pro hlubší analýzu, objevování a organizační využití'.

    NUKE GAZA! 🎆 | Komentářů: 5
    Které desktopové prostředí na Linuxu používáte?
     (1%)
     (5%)
     (1%)
     (13%)
     (35%)
     (9%)
     (8%)
     (6%)
     (15%)
     (33%)
    Celkem 127 hlasů
     Komentářů: 3, poslední včera 16:22
    Rozcestník

    Dotaz: C++ - Segmentation fault pri tvoreni array s velkosťou premenna

    25.10.2010 11:22 PeterS. | skóre: 10
    C++ - Segmentation fault pri tvoreni array s velkosťou premenna
    Přečteno: 454×

    Ahoj,
    takže mam niečo takéto:

    int img_size[6] ;    //tu uložim veľkosť obrazku
    img_size[0] = srcimg.width;    // = 1414
    img_size[1] = srcimg.height;    // = 1060
    float image_ar [img_size[0]*img_size[1]][4];

    skompiluje to ale pri spustení hodí "Chyba segmentacie..."
    Ak to tak  dam číslo, teda

    float image_ar  [3145728][4];

    tak ten array vytvorí. V čom by to mohlo byť?


    Řešení dotazu:


    Odpovědi

    25.10.2010 11:54 Jan Trávníček | skóre: 10 | blog: ehonza | Existuje
    Rozbalit Rozbalit vše Re: C++ - Segmentation fault pri tvoreni array s velkosťou premenna
    Pokud se nepletu tak velikost staticky definovaného pole musí být konstantní výraz. Jako řešení jedině použít malloc.
    To mess up a Linux box, you need to work at it; to mess up your Windows box, you just have to work on it.
    25.10.2010 12:02 trekker.dk | skóre: 72
    Rozbalit Rozbalit vše Re: C++ - Segmentation fault pri tvoreni array s velkosťou premenna
    Nepleteš se
    Quando omni flunkus moritati
    25.10.2010 12:18 PeterS. | skóre: 10
    Rozbalit Rozbalit vše Re: C++ - Segmentation fault pri tvoreni array s velkosťou premenna
    k dynamickemu alokovaniu pamäte som ešte nedošiel, ale podľa manualu by to mohlo byť takto?

    image_ar = new float [img_size[0]*img_size[1]][4];

    áno?
    Saljack avatar 25.10.2010 12:52 Saljack | skóre: 28 | blog: Saljack | Praha
    Rozbalit Rozbalit vše Re: C++ - Segmentation fault pri tvoreni array s velkosťou premenna
    Ano tohle by mělo fungovat.
    Sex, Drugs & Rock´n Roll.
    25.10.2010 14:39 PeterS. | skóre: 10
    Rozbalit Rozbalit vše Re: C++ - Segmentation fault pri tvoreni array s velkosťou premenna

    Doplnujúca otázka:
    urobil som niečo takéto:

    float * image_ar;             
    int ar_size = img_size[0]*img_size[1]*4;  //pomocná premenna, lebo v nasl riadku nechcelo brať vzorec ???
    image_ar = new float [ar_size];

    toto skompilovalo aj zbehlo bez problémov, "new" by malo hodiť výnimku keby neprebehlo, pokiaľ viem...
    lenže ja nechcem jednorozmernú array ale dvoj alebo trojrozmernú... čo s tým?

    25.10.2010 15:24 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: C++ - Segmentation fault pri tvoreni array s velkosťou premenna
      float (*image_ar)[4];
      image_ar = new float[img_size[0]*img_size[1]][4];
      ...
      delete [] image_ar;
    

    Případně si rozmyslete, jestli by z těch čtyř floatů nebylo rozumnější udělat strukturu nebo třídu.

    25.10.2010 15:36 PeterS. | skóre: 10
    Rozbalit Rozbalit vše Re: C++ - Segmentation fault pri tvoreni array s velkosťou premenna
    super, toto funguje...

    no ja sa učim a zaroven prepisujem program z pythonu, pri akej štrukture skončim je vo hviezdach...

    a celá ta array bude využitá, momentálne tie "vrstvy" planujem použiť na RGB hodnoty a celkový jas daného pixelu....
    Řešení 1× (Michy)
    25.10.2010 12:37 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: C++ - Segmentation fault pri tvoreni array s velkosťou premenna
    V C99 to lze, normu C++ jsem nezkoumal, ale gcc to přeloží i s -std=c++98, takže ani tam asi nebude problém. Problém je s velikostí toho pole - s hodnotami, které uvádí tazatel, se nemá šanci vejít na zásobník (a nevejde se tam ani s tou konstantou, kterou uvádí v dotazu). Pokud ale šířku a výšku dám např. 100, program se spustí a správně funguje. Takže řešením nakonec opravdu je dynamická alokace, i když z trochu jiného důvodu.
    Michy avatar 25.10.2010 13:00 Michy | skóre: 11 | Praha
    Rozbalit Rozbalit vše Re: C++ - Segmentation fault pri tvoreni array s velkosťou premenna
    Je to skutečně tak, staticky alokované pole je příliš velké, nevejde se do zásobníku, proto padá při spuštění na segmentation fault. Při dynamické alokaci, pomocí new, se vytváří v heapu a tam se obvykle vejde. Obecně je vhodné se vyhnout alokacím velkého množství paměti v zásobníku, protože jeho velikost je omezená zpravidla na jednotky MB.
    25.10.2010 13:04 Ivan
    Rozbalit Rozbalit vše Re: C++ - Segmentation fault pri tvoreni array s velkosťou premenna
    Tohle je pripad kdy C++ neni nadmnozinou C. V C++ opravdu pole musi mit znamou velikost. G++ to sezere, MSVC ne. Muzes bud pouzit malloc a naalokovat to na heapu anebo alloc a naalokovat to na stacku. S tim stackem muzes ale narazit na max. velikost zasobniku, hlavne u vice vlaknove aplikace. Velikost zasobniku na linuxu je defaultne 8MB, za timhle prostorem a jedna zamcena stranka a za ni zacina stack dalsiho vlakna(pokud existuje).
    25.10.2010 13:16 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: C++ - Segmentation fault pri tvoreni array s velkosťou premenna
    Ono ani na těch 8 MB není dobré moc spoléhat. U multithreadových aplikací běžně používám 512 KB, ale už jsem byl nucen jít i na 128 KB.

    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.