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 17:22 | IT novinky

    Byla představena nová verze modelu Claude Opus 4.6 od společnosti Anthropic. Jako demonstraci možností Anthropic využil 16 agentů Claude Opus 4.6 k vytvoření kompilátoru jazyka C, napsaného v programovacím jazyce Rust. Claude pracoval téměř autonomně, projekt trval zhruba dva týdny a náklady činily přibližně 20 000 dolarů. Výsledkem je fungující kompilátor o 100 000 řádcích kódu, jehož zdrojový kód je volně dostupný na GitHubu pod licencí Creative Commons.

    NUKE GAZA! 🎆 | Komentářů: 16
    včera 16:44 | Komunita

    Kultovní britský seriál The IT Crowd (Ajťáci) oslavil dvacáté výročí svého prvního vysílání. Sitcom o dvou sociálně nemotorných pracovnících a jejich nadřízené zaujal diváky svým humorem a ikonickými hláškami. Seriál, který debutoval v roce 2006, si i po dvou dekádách udržuje silnou fanouškovskou základnu a pravidelně se objevuje v seznamech nejlepších komedií své doby. Nedávné zatčení autora seriálu Grahama Linehana za hatecrime však vyvolává otázku, jestli by tento sitcom v současné Velké Británii vůbec vznikl.

    NUKE GAZA! 🎆 | Komentářů: 5
    včera 13:33 | IT novinky

    Společnost JetBrains oznámila, že počínaje verzí 2026.1 budou IDE založená na IntelliJ ve výchozím nastavení používat Wayland.

    Ladislav Hagara | Komentářů: 4
    včera 11:22 | IT novinky

    Společnost SpaceX amerického miliardáře Elona Muska podala žádost o vypuštění jednoho milionu satelitů na oběžnou dráhu kolem Země, odkud by pomohly zajistit provoz umělé inteligence (AI) a zároveň šetřily pozemské zdroje. Zatím se ale neví, kdy by se tak mělo stát. V žádosti Federální komisi pro spoje (FCC) se píše, že orbitální datová centra jsou nejúspornějším a energeticky nejúčinnějším způsobem, jak uspokojit rostoucí poptávku po

    … více »
    Ladislav Hagara | Komentářů: 22
    včera 11:11 | Nová verze

    Byla vydána nová verze 2.53.0 distribuovaného systému správy verzí Git. Přispělo 70 vývojářů, z toho 21 nových. Přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    včera 04:22 | Komunita

    Spolek OpenAlt zve příznivce otevřených řešení a přístupu na 216. sraz, který proběhne v pátek 20. února od 18:00 v Red Hat Labu (místnost Q304) na Fakultě informačních technologií VUT v Brně na ulici Božetěchova 1/2. Tématem srazu bude komunitní komunikační síť MeshCore. Jindřich Skácel představí, co je to MeshCore, předvede nejrůznější klientské zařízení a ukáže, jak v praxi vypadá nasazení vlastního repeateru.

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

    Byla vydána nová major verze 9.0 multiplatformní digitální pracovní stanice pro práci s audiem (DAW) Ardour. Přehled novinek, vylepšení a oprav v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    5.2. 13:55 | IT novinky

    Hodnota Bitcoinu, decentralizované kryptoměny klesla pod 70 000 dolarů (1,44 milionu korun).

    Ladislav Hagara | Komentářů: 14
    5.2. 13:22 | IT novinky

    Valve z důvodu nedostatku pamětí a úložišť přehodnocuje plán na vydání zařízení Steam Controller, Steam Machine a Steam Frame: „Cílem tedy stále zůstává vydat všechna tři nová zařízení v první polovině letošního roku, ale přesná data a ceny jsou dvě věci, na kterých usilovně pracujeme a jsme si dobře vědomi toho, jak rychle se v tomto ohledu může vše změnit. Takže ač dnes žádné zveřejnitelné údaje nemáme, hned jak plány finalizujeme, budeme Vás informovat.“

    Ladislav Hagara | Komentářů: 6
    5.2. 03:11 | Komunita

    Do 20. února lze hlasovat pro wallpapery pro Ubuntu 26.04 s kódovým názvem Resolute Raccoon.

    Ladislav Hagara | Komentářů: 2
    Které desktopové prostředí na Linuxu používáte?
     (19%)
     (6%)
     (0%)
     (10%)
     (25%)
     (3%)
     (4%)
     (2%)
     (12%)
     (29%)
    Celkem 789 hlasů
     Komentářů: 25, poslední 3.2. 19:50
    Rozcestník

    Dotaz: FreeBSD, pthreads a mutexy

    16.11.2010 09:28 chsajarsa | skóre: 16 | blog: V_hlouby_destneho_pralesa | Lovosice(Praha)
    FreeBSD, pthreads a mutexy
    Přečteno: 520×

    Zdravim, mam nasledujici kod kompilovany v FreeBSD 8.0-RELEASE-p4 pomoci g++ -pthread neco.cpp:

    #include <cstdlib>
    #include <iostream>
    #include <pthread.h>
    
    
    
    using namespace std;
    
    int main(int argc, char** argv) {
     pthread_mutex_t mymutex = PTHREAD_MUTEX_INITIALIZER;
     do {
         pthread_mutex_lock(&mymutex);
         std::cout << "Hello!!" << std::endl;
     } while (1);
     
     return 0;
    }

    Pod linuxem vse bezi jak ma (zasekne se na mutexu a zustane deadlock), ale na freebsd se cykluje vypisuje text porad dokola. U multithreadovych programu jede jen jednim threadem. Nevite prosim nekdo co delam spatne ? Diky

    ~ QED ~

    Odpovědi

    16.11.2010 10:54 Radim Kolář | skóre: 11
    Rozbalit Rozbalit vše Re: FreeBSD, pthreads a mutexy
    1. Ve freebsd je to dobre. Kdyz thread vlastni lock tak pri vicenasobnem zamykani nemusi uz cekat. Tuhle vlastnost melo freebsd odjakziva.

    2. Ze vas testovaci program kdyz je spusten vicevlaknove jede jen jednim vlaknem? Vzdyt to je to co se od nej ocekava, prave proto je tam ten mutex aby ty ostatni vlakne nejeli.
    16.11.2010 11:03 Vojtěch Horký | skóre: 39 | blog: Vojtův zápisník | Praha
    Rozbalit Rozbalit vše Re: FreeBSD, pthreads a mutexy
    1. Ve freebsd je to dobre. Kdyz thread vlastni lock tak pri vicenasobnem zamykani nemusi uz cekat. Tuhle vlastnost melo freebsd odjakziva.
    A určitě to má platit i pro pthread? Protože podle Single Unix Specification by se to mělo zablokovat, protože jde o normální mutex (nikoliv rekurzivní).
    I am always ready to learn although I do not always like to be taught. (W. Churchill)
    16.11.2010 14:53 chochi | skóre: 29 | Praha
    Rozbalit Rozbalit vše Re: FreeBSD, pthreads a mutexy
    Tady bych s tim nesouhlasil. Podle me dostupnych informaci je defaultni typ PTHREAD_MUTEX_DEFAULT, ktery podle odkazovaneho materialu:
    If the mutex type is PTHREAD_MUTEX_DEFAULT,
    attempting to recursively lock the mutex results in undefined behaviour.
    Attempting to unlock the mutex if it was not locked by the calling thread results in undefined behaviour.
    Attempting to unlock the mutex if it is not locked results in undefined behaviour.
    To ze v Linuxu je PTHREAD_MUTEX_DEFAULT = PTHREAD_MUTEX_NORMAL neni mozno ocekavat vsude (a ve FreeBSD to take neplati).
    18.11.2010 11:19 Vojtěch Horký | skóre: 39 | blog: Vojtův zápisník | Praha
    Rozbalit Rozbalit vše Re: FreeBSD, pthreads a mutexy
    Tady bych s tim nesouhlasil.
    A zcela správně ;-). Moje chyba: nějak jsem to nedočetl a předpokládal jsem, že NORMAL je výchozí hodnota vždy.

    Ze zvědavosti (protože jsem to nedokázal najít): ve FreeBSD platí PTHREAD_MUTEX_DEFAULT == PTHREAD_MUTEX_RECURSIVE nebo ten výchozí typ je nějaký speciální?
    I am always ready to learn although I do not always like to be taught. (W. Churchill)
    18.11.2010 14:09 chochi | skóre: 29 | Praha
    Rozbalit Rozbalit vše Re: FreeBSD, pthreads a mutexy
    Tak to presne rict nedokazu, jedine co jsem nasel je kousek ze souboru /usr/include/pthread.h:
    
    /*
     * Mutex types (Single UNIX Specification, Version 2, 1997).
     *
     * Note that a mutex attribute with one of the following types:
     *
     *  PTHREAD_MUTEX_NORMAL
     *  PTHREAD_MUTEX_RECURSIVE
     *
     * will deviate from POSIX specified semantics.
     */
    enum pthread_mutextype {
        PTHREAD_MUTEX_ERRORCHECK    = 1,    /* Default POSIX mutex */
        PTHREAD_MUTEX_RECURSIVE     = 2,    /* Recursive mutex */
        PTHREAD_MUTEX_NORMAL        = 3,    /* No error checking */
        PTHREAD_MUTEX_ADAPTIVE_NP   = 4,    /* Adaptive mutex, spins briefly before blocking on lock */
        PTHREAD_MUTEX_TYPE_MAX
    };
    
    #define PTHREAD_MUTEX_DEFAULT       PTHREAD_MUTEX_ERRORCHECK
    
    18.11.2010 14:55 Vojtěch Horký | skóre: 39 | blog: Vojtův zápisník | Praha
    Rozbalit Rozbalit vše Re: FreeBSD, pthreads a mutexy
    Tak podle tohohle (protože PTHREAD_MUTEX_INITIALIZER by měl použít PTHREAD_MUTEX_DEFAULT) by výchozí mutex neměl být rekurzivní, ale pouze error checking a tudíž by ten původní kód měl zamknout mutex (při prvním cyklu) a následné volání by mělo vracet EDEADLK. Je to tak nebo je tam ještě nějaký háček? Dík
    I am always ready to learn although I do not always like to be taught. (W. Churchill)
    18.11.2010 15:11 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: FreeBSD, pthreads a mutexy
    Mělo by to tak být. Mělo by to jít snadno poznat tak, že přidáte kontrolu návratové hodnoty.
    18.11.2010 15:36 Vojtěch Horký | skóre: 39 | blog: Vojtův zápisník | Praha
    Rozbalit Rozbalit vše Re: FreeBSD, pthreads a mutexy
    Mělo by to jít snadno poznat tak, že přidáte kontrolu návratové hodnoty.
    To je mi jasný ;-), jen nemám kde si to vyzkoušet a tak se ptám.
    I am always ready to learn although I do not always like to be taught. (W. Churchill)
    16.11.2010 11:23 chsajarsa | skóre: 16 | blog: V_hlouby_destneho_pralesa | Lovosice(Praha)
    Rozbalit Rozbalit vše Re: FreeBSD, pthreads a mutexy

    1. Pokud je to tak jak rikate, tak cim muzu zajistit, aby se muj ukazkovy program choval podle ocekavani(tedy stejne jako na linuxu)? Mam ideu,ze budu mit vytvorena vlakna, ktera budou zastavena pomoci toho mutexu. Ja do nich v pripade potreby narvu data (zmenim data v objektu,ktery ma ta fce vlakna predany jako parametr) a vlaknu pustim odemcenim mutexu a po dokonceni operace se vlakno v cyclu zase vrati k tomu zamcenemu mutexu. Chci tak ridit thread pool pro obsluhu site. Tedy:

    Pracovni vlakno:

    for(;;){
     pthread_mutex_lock(&mymutex);
     do_work();
     pthread_mutex_lock(&mymutex);
    }
    

     

    A odemikani pak v jinem vlakne pomoci:

    pthread_mutex_unlock(&mymutex);
    
    ~ QED ~
    16.11.2010 11:32 Vojtěch Horký | skóre: 39 | blog: Vojtův zápisník | Praha
    Rozbalit Rozbalit vše Re: FreeBSD, pthreads a mutexy
    A odemikani pak v jinem vlakne pomoci: pthread_mutex_unlock(&mymutex);
    Nesmíte odemykat mutex v jiném vlákně, než které ho zamklo (resp. ono to možná někde bude fungovat, ale ...).

    Na to, co popisujete, jsou tu podmínkové proměnné, v pthread funkce pthread_cond_wait & spol.
    I am always ready to learn although I do not always like to be taught. (W. Churchill)

    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.