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 03:44 | Komunita

    V Bolzanu probíhá konference SFSCON (South Tyrol Free Software Conference). Jean-Baptiste Kempf, zakladatel a prezident VideoLAN a klíčový vývojář VLC media playeru, byl na ní oceněn cenou European SFS Award 2025 udělovanou Free Software Foundation Europe (FSFE) a Linux User Group Bolzano‑Bozen (LUGBZ).

    Ladislav Hagara | Komentářů: 0
    dnes 02:44 | Zajímavý projekt

    Open-source minimalistický trackball Ploopy Nano byl po modelech modelech Classic a Thumb Trackball také aktualizován. Nová verze Nano 2 používá optický senzor PAW3222 a k původně beztlačítkovému designu přidává jedno tlačítko, které ve výchozí konfiguraci firmwaru QMK přepíná režim posouvání koulí. Sestavený trackball nyní vyjde na 60 kanadských dolarů (bez dopravy a DPH).

    |🇵🇸 | Komentářů: 0
    včera 14:22 | Zajímavý článek

    Github publikoval Octoverse 2025 (YouTube), tj. každoroční přehled o stavu open source a veřejných softwarových projektů na GitHubu. Každou sekundu se připojil více než jeden nový vývojář. Nejpoužívanějším programovacím jazykem se stal TypeScript.

    Ladislav Hagara | Komentářů: 0
    včera 09:55 | Komunita

    Kit je nový maskot webového prohlížeče Firefox.

    Ladislav Hagara | Komentářů: 14
    včera 00:11 | Nová verze

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

    Ladislav Hagara | Komentářů: 2
    6.11. 23:55 | IT novinky

    Německo zvažuje, že zaplatí místním telekomunikačním operátorům včetně Deutsche Telekom, aby nahradili zařízení od čínské firmy Huawei. Náklady na výměnu by mohly přesáhnout dvě miliardy eur (bezmála 49 miliard Kč). Jeden scénář počítá s tím, že vláda na tento záměr použije prostředky určené na obranu či infrastrukturu.

    Ladislav Hagara | Komentářů: 1
    6.11. 18:00 | Komunita

    Po dvaceti letech skončil leader japonské SUMO (SUpport.MOzilla.org) komunity Marsf. Důvodem bylo nasazení sumobota, který nedodržuje nastavené postupy a hrubě zasahuje do překladů i archivů. Marsf zároveň zakázal použití svých příspěvků a dat k učení sumobota a AI a požádal o vyřazení svých dat ze všech učebních dat.

    karkar | Komentářů: 9
    6.11. 11:00 | IT novinky

    Úřad pro ochranu hospodářské soutěže zahajuje sektorové šetření v oblasti mobilních telekomunikačních služeb poskytovaných domácnostem v České republice. Z poznatků získaných na základě prvotní analýzy provedené ve spolupráci s Českým telekomunikačním úřadem (ČTÚ) ÚOHS zjistil, že vzájemné vztahy mezi operátory je zapotřebí detailněji prověřit kvůli možné nefunkčnosti některých aspektů konkurence na trzích, na nichž roste tržní podíl klíčových hráčů a naopak klesá význam nezávislých virtuálních operátorů.

    Ladislav Hagara | Komentářů: 16
    6.11. 10:55 | Humor

    Různé audity bezpečnostních systémů pařížského muzea Louvre odhalily závažné problémy v oblasti kybernetické bezpečnosti a tyto problémy přetrvávaly déle než deset let. Jeden z těchto auditů, který v roce 2014 provedla francouzská národní agentura pro kybernetickou bezpečnost, například ukázal, že heslo do kamerového systému muzea bylo „Louvre“. 😀

    Ladislav Hagara | Komentářů: 15
    6.11. 01:00 | Komunita

    Z upstreamu GNOME Mutter byl zcela odstraněn backend X11. GNOME 50 tedy poběží už pouze nad Waylandem. Aplikace pro X11 budou využívat XWayland.

    Ladislav Hagara | Komentářů: 19
    Jaké řešení používáte k vývoji / práci?
     (36%)
     (48%)
     (18%)
     (17%)
     (22%)
     (15%)
     (21%)
     (15%)
     (16%)
    Celkem 324 hlasů
     Komentářů: 15, poslední 2.11. 08:25
    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: 430×

    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.