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 11:00 | Komunita

Členové a příznivci spolku OpenAlt se pravidelně schází v Praze a Brně. Fotky z pražských srazů za uplynulý rok si můžete prohlédnout na stránkách spolku. Příští sraz se koná už zítra 19. ledna – tentokrát je tématem ergonomie ovládání počítače – tzn. klávesnice, myši a další zařízení. Také budete mít příležitost si prohlédnout pražský hackerspace Brmlab.

xkucf03 | Komentářů: 0
včera 21:55 | Komunita

Nadace pro svobodný software (FSF) oznámila aktualizaci seznamu prioritních oblastí (changelog), na které by se měli vývojáři a příznivci svobodného softwaru zaměřit. Jsou to například svobodný operační systém pro chytré telefony, hlasová a video komunikace nebo softwarový inteligentní osobní asistent.

Ladislav Hagara | Komentářů: 4
včera 16:44 | Nová verze

Byla vydána verze 2.0.0 knihovny pro vykreslování grafů v programovacím jazyce Python Matplotlib (Wikipedie, GitHub). Přehled novinek a galerie grafů na stránkách projektu.

Ladislav Hagara | Komentářů: 0
včera 15:33 | Komunita

V australském Hobartu probíhá tento týden konference linux.conf.au 2017. Na programu je celá řada zajímavých přednášek. Sledovat je lze online.

Ladislav Hagara | Komentářů: 0
včera 10:20 | Zajímavý článek

Pavel Tišnovský se v dvoudílném článku na MojeFedora.cz věnuje bitmapovým (rastrovým) grafickým editorům ve Fedoře. V prvním dílu se věnuje editorům MyPaint, MtPaint, Pinta, XPaint, Krita a GIMP. V pokračování pak editorům GNU Paint (gpaint), GrafX2, KolourPaint, KIconEdit a Tux Paint.

Ladislav Hagara | Komentářů: 1
16.1. 17:11 | Komunita

Byl proveden bezpečnostní audit svobodného IMAP a POP3 serveru Dovecot (Wikipedie). Audit byl zaplacen z programu Mozilla Secure Open Source a provedla jej společnost Cure53. Společnost Cure53 byla velice spokojena s kvalitou zdrojových kódu. V závěrečné zprávě (pdf) jsou zmíněny pouze 3 drobné a v upstreamu již opravené bezpečnostní chyby.

Ladislav Hagara | Komentářů: 0
16.1. 15:30 | IT novinky

Nadace Raspberry Pi představila na svém blogu Raspberry Pi Compute Module 3 (CM3 a CM3L), tj. zmenšené Raspberry Pi vhodné nejenom pro průmyslové využití. Jedná se o nástupce Raspberry Pi Compute Module (CM1) představeného v dubnu 2014. Nový CM3 vychází z Raspberry Pi 3 a má tedy dvakrát více paměti a desetkrát větší výkon než CM1. Verze CM3L (Lite) je dodávána bez 4 GB eMMC flash paměti. Uživatel si může připojit svou vlastní. Představena byla

… více »
Ladislav Hagara | Komentářů: 2
16.1. 01:23 | Nová verze

Oficiálně bylo oznámeno vydání verze 3.0 multiplatformního balíku svobodných kancelářských a grafických aplikací Calligra (Wikipedie). Větev 3 je postavena na KDE Frameworks 5 a Qt 5. Krita se osamostatnila. Z balíku byly dále odstraněny aplikace Author, Brainstorm, Flow a Stage. U Flow a Stage se předpokládá jejich návrat v některé z budoucích verzí Calligry.

Ladislav Hagara | Komentářů: 7
15.1. 15:25 | Nová verze

Bylo oznámeno vydání první RC (release candidate) verze instalátoru pro Debian 9 s kódovým názvem Stretch. Odloženo bylo sloučení /usr jako výchozí nastavení v debootstrap. Vydán byl také Debian 8.7, tj. sedmá opravná verze Debianu 8 s kódovým názvem Jessie.

Ladislav Hagara | Komentářů: 6
15.1. 13:37 | Zajímavý projekt

1. ledna byl představen projekt Liri (GitHub). Jedná se o spojení projektů Hawaii, Papyros a původního projektu Liri s cílem vyvíjet operační systém (linuxovou distribuci) a aplikace s moderním designem a funkcemi. Včera byl představen Fluid 0.9.0 a také Vibe 0.9.0. Jedná se o toolkit a knihovnu pro vývoj multiplatformních a responzivních aplikací podporující Material Design (Wikipedie) a volitelně také Microsoft Design Language (designový jazyk Microsoft) [reddit].

Ladislav Hagara | Komentářů: 9
Jak se stavíte k trendu ztenčování přenosných zařízení (smartphony, notebooky)?
 (10%)
 (2%)
 (74%)
 (3%)
 (10%)
Celkem 309 hlasů
 Komentářů: 24, poslední včera 10:14
    Rozcestník
    Reklama

    Dotaz: C++ inicializace statických proměnných

    8.11.2011 22:22 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    C++ inicializace statických proměnných
    Přečteno: 877×
    Příloha:
    Ahojte, dlouho tu nebyl žádný dotaz na C++…
    Máme C++ (level nechám na uvážení, jestli teda C++0x má „statický“ konstruktor, tak je to jasné a proto snížíme level :-))
    Máme třídu která má jen statické proměnné a fce (statická class).
    Máme minimálně dvě (a více) priváte statických proměnných, které vyžadují „složitou“ inicializace a navíc ta inicializace potřebuje pracovat s těmito proměnnými současně.
    Nemůžeme použít public funkci na inicializace.
    Nemůžeme použít odloženou inicializaci (vnitřní automatická inicializace při první potřebě použití těchto proměnných).

    První otázka: „Jaká jsou řešení?“

    Jedno řešení: první (1. až n.-1) proměnné klasicky nastavíme na „něco prázdné či základní“ a poslední inicializujeme privátní statickou metodou, ve které uděláme patřičné inicializace všech proměnných.
    V příloze je třída demonstrující tuto záležitost jednoduchým způsobem (compilovatelné).

    Druhá otázka: Toto uvedené řešení je přenositelné a pořadí inicializace, které je zde vyžadováno je zaručeno standardem (špatně jsem hledal - nanašel a jsem přesvědčen, že ano pokud to bude v jednom cpp-čku)?
    PS: GCC init_priority nebereme v potaz.

    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†

    Řešení dotazu:


    Odpovědi

    9.11.2011 13:09 Ondra Holub | skóre: 6
    Rozbalit Rozbalit vše Re: C++ inicializace statických proměnných
    Udělal bych to, jak píšeš. Tedy nejdříve všechno nějakým základním způsobem nainicializovat a pak to "doinicializovat" v posledním kroku.

    Osobně pro zavolání komplexnější inicializační funkce používám nějakou statickou dummy boolovskou proměnnou, která se nainicializuje voláním té inicializační funkce. Něco jako:
    std::map< int,int >  staticClass::map1; // Tady se to inicializuje default construktorem
    std::map< int,int* > staticClass::map2; // Take inicializace default constructorem
    
    static const bool init = staticClass::createMaps(); // createMaps musi samozrejme pak vracet bool, idealne true
    
    
    Proměnnou init je možné někam schovat, třeba jako private membera nějaké třídy nebo do anonymního namespace.

    Pokud by se takto inicializovaly statické proměnné z template třídy a "dummy" init proměnná by byla také templatovaná, je potřeba dát si pozor na to, aby ta "dummy" proměnná init byla někde použita. Jinak ji překladač vyoptimalizuje a tudíž vyoptimalizuje i volání její inicializace.

    Nejsem si jist, jestli poslední odstavec dotazu je otázka, jestli je pořadí inicializace zaručeno standardem. Každopádně tvrdím, že je, ovšem jenom v rámci jedné kompilační jednotky (tedy jeden zdroják obsahující všechny includované headery).
    9.11.2011 15:20 graviton
    Rozbalit Rozbalit vše Re: C++ inicializace statických proměnných
    Ad otázka z posledního odstavce - standard [basic.start.init]: "Objects with ordered initialization defined within a single translation unit shall be initialized in the order of their definitions in the translation unit." - tvrzení je podpořené i standardem.
    9.11.2011 17:34 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: C++ inicializace statických proměnných
    To je dobré, ta proměnná 'init' může být private té inicializované třídy a nemusí být nutně const a pak lehce lze otočit funkcionalitu(bez změny rozhraní) na „odloženou inicializaci“ a tuto proměnnou použít jako indikátor inicializace.
    Ale hlavně to na mě působí čistěji-čitelněji, protože všechny „nutné“ proměnné jsou inicializovány stejně a jen jedna „speciální“ se stará o tu vyšší logiku.
    PS: nejsem si fčul jist, ale pokud je std::map< int,int > staticClass::map; member of class, tak je třeba aby byla explicitně uvedena inicializace tedy std::map< int,int > staticClass::map1 = std::map< int,int >();.
    Ano druhou otázku chápeš dobře, a odpověď je tak jak jsem přesvědčen, že to je, ale nedokázal jsem si své přesvědčení verifikovat nalezením nějakým odkazu na standard.
    Dík - později to označím jako řešení, aby to zatím někoho neodradilo k případným dalším návrhům :-).
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    9.11.2011 13:45 Ivan
    Rozbalit Rozbalit vše Re: C++ inicializace statických proměnných
    Podivej se na knihu Andrei Alexandrescu: Modern C++ Design: Generic Programming. Tam je to pekne popsano v kapitole o Singletonech. Resi se tam i mnohem komplikovanijesi priklad - destrukce statickych promennych.

    Popr. je to implementovano v knihovne Loki od stejneho autora.
    9.11.2011 17:11 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: C++ inicializace statických proměnných
    Samozřejmě dík za tip, jestli se napletu, už by měla být doma, připravena k přečtení.
    Předjímám, ale Singleton není obvykle statická třída, nebo právě k vůli inicializaci a úklidu není vhodné jej tak implementovat…
    Mohl jsi písnout to řešení :-)
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    9.11.2011 21:29 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: C++ inicializace statických proměnných
    Tak jsem to zkoukl a nenašel jsem tam žádné řešení odpovídající zadání.
    Řeší se tam docela obšírně jak implementovat Singleton a jak manipulovat s jeho daty a hezky je to vyjádřeno na začátku Static Data + Static Functions != Singleton.
    Singletom jako takový není, podle mě, řešením, ale řešením můžete implementovat Singleton.
    Můj dotaz byl „nižšího“ charakteru…
    Můžeme se bavit o tom, že otázka je nesprávná a měla znít „Co dostanete, když vynásobíte šest devíti?“, ale to by zas odpověď byla „42“ :-).
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†

    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.