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 14:44 | Zajímavý software

    Brush (Bo(u)rn(e) RUsty SHell) je v Rustu napsaný shell kompatibilní s Bash (Bourne Again SHell). Vydána byla verze 0.4.0.

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

    Google zveřejnil seznam 1 141 projektů (vývojářů) od 184 organizací přijatých do letošního, již dvaadvacátého, Google Summer of Code. Přihlášeno bylo celkově 23 371 projektů od 15 245 vývojářů ze 131 zemí.

    Ladislav Hagara | Komentářů: 1
    dnes 03:00 | Komunita

    Na čem pracovali vývojáři GNOME a KDE Plasma minulý týden? Pravidelný přehled novinek v Týden v GNOME a Týden v KDE Plasma.

    Ladislav Hagara | Komentářů: 0
    včera 03:44 | Nová verze

    Open source počítačová hra na hrdiny NetHack (Wikipedie, GitHub) byla vydána v nové verzi 5.0.0. První verze této hry byla vydána v roce 1987.

    Ladislav Hagara | Komentářů: 2
    1.5. 15:11 | IT novinky

    Evropská komise naléhavě vyzvala členské státy EU, aby kvůli ochraně nezletilých na internetu urychlily zavádění unijní aplikace pro ověřování věku a zajistily její dostupnost do konce roku. Členské státy mohou zavést aplikaci EU pro ověřování věku jako samostatnou aplikaci nebo ji integrovat do takzvané evropské peněženky digitální identity.

    Ladislav Hagara | Komentářů: 39
    30.4. 23:33 | Nová verze

    Richard Biener oznámil vydání verze 16.1 (16.1.0) kolekce kompilátorů pro různé programovací jazyky GCC (GNU Compiler Collection). Jedná se o první stabilní verzi řady 16. Přehled změn, nových vlastností a oprav a aktualizovaná dokumentace na stránkách projektu. Některé zdrojové kódy, které bylo možné přeložit s předchozími verzemi GCC, bude nutné upravit.

    Ladislav Hagara | Komentářů: 0
    30.4. 23:11 | Nová verze

    Zulip Server z open source komunikační platformy Zulip (Wikipedie, GitHub) byl vydán ve verzi 12.0. Přehled novinek v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 0
    30.4. 12:11 | IT novinky

    Před 30 lety, tj. v úterý 30. dubna 1996, byl spuštěn Seznam.cz.

    Ladislav Hagara | Komentářů: 44
    30.4. 11:44 | Komunita

    Byly zpracovány a zveřejněny všechny videozáznamy, které stojí za zveřejnění, z konference FOSDEM 2026.

    Ladislav Hagara | Komentářů: 0
    30.4. 01:11 | IT novinky

    Od úterý 28. dubna musí nově uváděné notebooky v Evropské unii podporovat nabíjení přes USB-C. Jednotná nabíječka byla schválena Evropským parlamentem v říjnu 2022.

    Ladislav Hagara | Komentářů: 58
    Které desktopové prostředí na Linuxu používáte?
     (14%)
     (9%)
     (2%)
     (14%)
     (31%)
     (4%)
     (7%)
     (3%)
     (16%)
     (24%)
    Celkem 1494 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    Rozcestník

    Dotaz: Vlakna a mutex v C++

    13.8.2012 10:57 bajo21
    Vlakna a mutex v C++
    Přečteno: 620×
    Cavte, mam taku otazku. C++.
    Mam zakladny beh aplikacie a z neho vytvaram vlakna (boost::thread), tam bezi (USB kamera, AVI player, RS232 virtual port). Problem vysvetlim na objekte std::cout . Jedna sa o staticky objekt, globalne deklarovany, ktory pouziva pretazny operator << ;
    Podobne
    cout << "vypis" << premenna;
    si robim vypisovanie v konzole, objekt std::cout sa ale moze volat pre vypis bud z hlavnej aplikacie alebo z vlaknien. Podla vas je nutne kazde volanie objektu std::cout << nieco; uzamikat mutexom (boost::mutex)? Lebo mi aplikacia pada po par dnoch a neviem, ci to moze byt tym, ze saham v rovnakom case z roznych vlakien do rovnakej pamate objektu std::cout; . Dik za radu :).

    Odpovědi

    13.8.2012 11:39 Dadam | skóre: 12 | blog: dadamovo
    Rozbalit Rozbalit vše Re: Vlakna a mutex v C++
    Já jsem výpis (v mém případě do logu) řešil tak, že jsem si udělal třídu Log, která se chová jako istream, v destruktoru si zamkne soubor statickým mutexem a zaráz do něj zapíše co má. Použití by pak vypadá nějak takto:
    Log() << "velikost cehosi: " << cosi.velikost();
    Co se týče pádu po několika dnech, nemáš tam memory leak? Zkus to projet valgrindem, zkus si pomocí htop zjistit co ta aplikace po pár dnech zabere (valgrind ti nezjistí virtuální úniky).
    A i B mají svoje výhody a nevýhody. Vyberte si to, co vám vyhovuje víc, a necpěte A tam, kam patří B.
    13.8.2012 11:40 vvv
    Rozbalit Rozbalit vše Re: Vlakna a mutex v C++
    Mozna je tohle do budoucna reseno novym memory modelem a vlakny, ale v tuhle chvili bych rekl, ze se na to obecne spolehat nemuzes, rozhodne ne na vsech platformach.
    13.8.2012 13:41 Ivan
    Rozbalit Rozbalit vše Re: Vlakna a mutex v C++
    Na podobny logovani jsem pouzil clanek, ktery napsal John Torjo:

    http://articles.techrepublic.com.com/5100-10878_11-5072104.html#

    Trochu jsem to prekopal, a nakonec jsem dospel k tomuhle: https://tora.svn.sourceforge.net/svnroot/tora/branches/tora3/src/ts_log

    Ber to s hodne velkou rezervou, neni to kod na kterej bych byl pysnej. Dneska si myslim, ze pouzivani streamu na logovani je zbytecne slozity a nic to neprinasi.

    PS: nedelas to nahodou na woknach? Jeste pred lety byly se na MSVC velky problemy - memory leaky, segfaulty.
    13.8.2012 13:50 bajo21
    Rozbalit Rozbalit vše Re: Vlakna a mutex v C++
    Ja pouzivam automaticku spravu pamate, nieco ako (boost shared_ptr), tak memory leak je malo pravdepodobny a pozorujem RAM pre GPU aj CPU, ale neviem ako je na tom CACHE :). Robim OpenGL, v okne :). Tiez mam podobne spraveny log system, len ho nemam chraneny mutexom, mozno je aj v tom problem, musim to pozriet, ale vysledok budem vediet tak o tyzden, zalezi kedy to spadne :). Dakujem za rady :).
    13.8.2012 15:42 Sten
    Rozbalit Rozbalit vše Re: Vlakna a mutex v C++
    Samozřejmě to možné je, ale je to velice velice nepravděpodobné. Zkusil jste alspoň získat backtrace nebo jenom tak naslepo hádáte?

    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.