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í
×
    včera 12:55 | Nová verze

    CiviCRM (Wikipedie) bylo vydáno v nové verzi 6.14.0. Podrobnosti o nových funkcích a opravách najdete na release stránce. CiviCRM je robustní open-source CRM systém navržený speciálně pro neziskové organizace, spolky a občanské iniciativy. Projekt je napsán v jazyce PHP a licencován pod GNU Affero General Public License (AGPLv3). Český překlad má nyní 45 % přeložených řetězců a přibližuje se milníku 50 %. Potřebujeme vaši pomoc, abychom se dostali dál. Pokud máte chuť přispět překladem nebo korekturou, přidejte se na platformu Transifex.

    jardaIT | Komentářů: 1
    včera 12:22 | Bezpečnostní upozornění

    Další lokální zranitelností Linuxu je ssh-keysign-pwn. Uživatel si může přečíst obsah souborů, ke kterým má právo ke čtení pouze root, například soubory s SSH klíči nebo /etc/shadow. V upstreamu již opraveno [oss-security mailing list].

    Ladislav Hagara | Komentářů: 0
    14.5. 17:22 | Komunita

    Singularity (YouTube) je nejnovější otevřený film od Blender Studia. Jedná se o jejich první 4K HDR film.

    Ladislav Hagara | Komentářů: 0
    14.5. 16:55 | Zajímavý software

    Vyšla hra Život Není Krásný: Poslední Exekuce (Steam, ProtonDB). Kreslená point & click adventura ze staré školy plná černého humoru a nekorektního násilí. Vžijte se do role zpustlého exekutora Vladimíra Brehowského a projděte s ním jeho poslední pracovní den. Hra volně navazuje na sérii Život Není Krásný.

    Ladislav Hagara | Komentářů: 23
    14.5. 14:00 | Zajímavý projekt

    Společnost Red Hat představila Fedora Hummingbird, tj. linuxovou distribuci s nativním kontejnerovým designem určenou pro vývojáře využívající AI agenty.

    Pinhead | Komentářů: 6
    14.5. 02:22 | Zajímavý software

    Hru The Legend of Zelda: Twilight Princess od společnosti Nintendo si lze nově díky projektu Dusklight (původně Dusk) a reverznímu inženýrství zahrát i na počítačích a mobilních zařízeních. Vyžadována je kopie původní hry (textury, modely, hudba, zvukové efekty, …). Ukázka na YouTube. Projekt byl zahájen v srpnu 2020.

    Ladislav Hagara | Komentářů: 0
    14.5. 01:11 | Nová verze

    Byla vydána nová major verze 29.0 programovacího jazyka Erlang (Wikipedie) a související platformy OTP (Open Telecom Platform, Wikipedie). Detailní přehled novinek na GitHubu.

    Ladislav Hagara | Komentářů: 0
    13.5. 21:22 | Bezpečnostní upozornění

    Po zranitelnostech Copy Fail a Dirty Frag přichází zranitelnost Fragnesia. Další lokální eskalace práv na Linuxu. Zatím v upstreamu neopravena. Přiřazeno ji bylo CVE-2026-46300.

    Ladislav Hagara | Komentářů: 1
    13.5. 14:00 | Komunita

    Sovereign Tech Agency (Wikipedie) prostřednictvím svého fondu Sovereign Tech Fund podpoří KDE částkou 1 285 200 eur.

    Ladislav Hagara | Komentářů: 12
    13.5. 12:55 | IT novinky

    Google na včerejší akci The Android Show | I/O Edition 2026 (YouTube) představil celou řadu novinek: Gemini Intelligence, notebooky Googlebook, novou generaci Android Auto, …

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

    Dotaz: C++, inicializace pole

    16.3.2006 19:30 Michal K.
    C++, inicializace pole
    Přečteno: 1619×
    Dobry den.

    Potrebuji inicializovat pole v c++ a to touto kontrukci: int pole[]={1,2,3,4,5};

    Problem je v tom, ze ono pole je private atribut jedne tridy (o jeho inicializaci se snazim prave v jejim konstruktoru) a g++ mi vyhazuje tuto chybu: expected primary-expression before ']' token

    Nevite nekdo co s tim? Potrebuju inicializovat pole takto, ne clen po clenu (pole[0]=0;pole[1]=1,...).

    Dekuji.

    Odpovědi

    Luboš Doležel (Doli) avatar 16.3.2006 19:38 Luboš Doležel (Doli) | skóre: 98 | blog: Doliho blog | Kladensko
    Rozbalit Rozbalit vše Re: C++, inicializace pole
    1. Musíte určit velikost pole.
    2. {...} do konstruktoru asi nenacpete.
    Luboš Doležel (Doli) avatar 16.3.2006 19:39 Luboš Doležel (Doli) | skóre: 98 | blog: Doliho blog | Kladensko
    Rozbalit Rozbalit vše Re: C++, inicializace pole
    Navrhoval bych v konstruktoru udělat třeba tohle:
    const int pole[5] = {1,2,3,4,5};
    memcpy(m_pole,pole,sizeof(pole));
    16.3.2006 20:37 jekub | skóre: 9 | blog: noblog
    Rozbalit Rozbalit vše Re: C++, inicializace pole
    class X {
       int *m_pole;
       int m_size;
    public:
       X() {
          static int pole[] = {1, 2, 3, 4, 5};
          m_pole = pole;
          m_size = sizeof pole / sizeof pole[0];
       }
       .
       .
       .
    };
    
    Luboš Doležel (Doli) avatar 16.3.2006 20:42 Luboš Doležel (Doli) | skóre: 98 | blog: Doliho blog | Kladensko
    Rozbalit Rozbalit vše Re: C++, inicializace pole
    Otázka je, jaký smysl má pak m_pole. Když už staticky, tak je čistší udělat tohle:

    Header:
    class X
    {
       static int m_pole[];
    };
    
    Cpp:
    int X::m_pole[] = { ... };
    16.3.2006 20:49 jekub | skóre: 9 | blog: noblog
    Rozbalit Rozbalit vše Re: C++, inicializace pole
    Jo, máte pravdu. Ale mám dojem, že když jsem naposled tohle zkoušel, tak to v (MSVC) nefungovalo a nějak jsem si to zafixoval. Dík za upozornění.
    16.3.2006 20:43 jekub | skóre: 9 | blog: noblog
    Rozbalit Rozbalit vše Re: C++, inicializace pole
    Ale pokud má být pole konstantní (dovedu si představit i případ, kdy ne), tak raději
    class X {
       const int *m_pole;
       int m_size;
    public:
       X() {
          static const int pole[] = {1, 2, 3, 4, 5};
          m_pole = pole;
          m_size = sizeof pole / sizeof pole[0];
       }
       .
       .
       .
    };
    
    Luboš Doležel (Doli) avatar 16.3.2006 20:48 Luboš Doležel (Doli) | skóre: 98 | blog: Doliho blog | Kladensko
    Rozbalit Rozbalit vše Re: C++, inicializace pole
    Tak to je ještě větší hnus. Když už máte konstatní pole, tak je strašně neefektivní kvůli němu zakládat dvě proměnné v teoreticky nekonstatních objektech (instancích třídy X).
    16.3.2006 20:51 jekub | skóre: 9 | blog: noblog
    Rozbalit Rozbalit vše Re: C++, inicializace pole
    Souhlas, viz výše.
    16.3.2006 20:57 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: C++, inicializace pole
    Prvkem třídy nemůže být objekt s proměnnou velikostí. Takže pokud by to pole mělo mít různou velikost pro různé instance třídy, bylo by potřeba ho alokovat dynamicky a vzniká otázka, jak potom udělat konstruktor (může být třeba konstruktor variadická funkce?). Stylově čistší by ale asi bylo místo pole použít std::vector<int>, pak by se nejspíš něco vymyslet dalo.
    16.3.2006 21:05 Sinuhet | skóre: 31
    Rozbalit Rozbalit vše Re: C++, inicializace pole
    Prvkem třídy nemůže být objekt s proměnnou velikostí. Takže pokud by to pole mělo mít různou velikost pro různé instance třídy, bylo by potřeba ho alokovat dynamicky ...
    Nebo, pokud zname velikost pole v dobe kompilace, stvorit sablonu.
    ... a vzniká otázka, jak potom udělat konstruktor (může být třeba konstruktor variadická funkce?).
    Ano muze.
    16.3.2006 21:37 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: C++, inicializace pole
    Prostě by to chtělo vědět spoustu dodatečných informací - jestli je obsah nebo aspoň velikost toho pole univerzální pro všechny instance, jestli je velikost známa už při kompilaci nebo až za běhu, a k čemu to vlastně má sloužit. Ono je totiž docela dobře možné, že kdybychom tyto informace měli, našlo by se daleko elegantnější řešení založené na něčem úplně jiném.

    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.