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 13:00 | Humor

    Agent umělé inteligence Claude Opus ignoroval uživatelovu odpověď 'ne' na dotaz, zda má implementovat změny kódu, a přesto se pokusil změny provést. Agent si odpověď 'ne' vysvětlil následovně: Uživatel na mou otázku 'Mám to implementovat?' odpověděl 'ne' - ale když se podívám na kontext, myslím, že tím 'ne' odpovídá na to, abych žádal o svolení, tedy myslí 'prostě to udělej, přestaň se ptát'.

    NUKE GAZA! 🎆 | Komentářů: 3
    dnes 00:44 | IT novinky

    Po 8. květnu 2026 už na Instagramu nebudou podporované zprávy opatřené koncovým šifrováním. V chatech, kterých se bude změna týkat, se objeví pokyny o tom, jak si média nebo zprávy z nich stáhnout, pokud si je chcete ponechat.

    Ladislav Hagara | Komentářů: 4
    dnes 00:33 | IT novinky

    V lednu byla ve veřejné betě obnovena sociální síť Digg (Wikipedie). Dnes bylo oznámeno její ukončení (Hard Reset). Společnost Digg propouští velkou část týmu a přiznává, že se nepodařilo najít správné místo na trhu. Důvody jsou masivní problém s boty a silná konkurence. Společnost Digg nekončí, malý tým pokračuje v práci na zcela novém přístupu. Cílem je vybudovat platformu, kde lze důvěřovat obsahu i lidem za ním. Od dubna se do Diggu na plný úvazek vrací Kevin Rose, zakladatel Diggu z roku 2004.

    Ladislav Hagara | Komentářů: 5
    včera 12:33 | Zajímavý projekt

    MALUS je kontroverzní proprietarní nástroj, který svým zákazníkům umožňuje nechat AI, která dle tvrzení provozovatelů nikdy neviděla původní zdrojový kód, analyzovat dokumentaci, API a veřejná rozhraní jakéhokoliv open-source projektu a následně úplně od píky vygenerovat funkčně ekvivalentní software, ovšem pod libovolnou licencí.

    NUKE GAZA! 🎆 | Komentářů: 16
    včera 03:55 | Bezpečnostní upozornění

    Příspěvek na blogu Ubuntu upozorňuje na několik zranitelností v rozšíření Linuxu o mandatorní řízení přístupu AppArmor. Společně jsou označovány jako CrackArmor. Objevila je společnost Qualys (technické detaily). Neprivilegovaný lokální uživatel se může stát rootem. Chyba existuje od roku 2017. Doporučuje se okamžitá aktualizace. Problém se týká Ubuntu, Debianu nebo SUSE. Red Hat nebo Fedora pro mandatorní řízení přístupu používají SELinux.

    Ladislav Hagara | Komentářů: 2
    12.3. 17:22 | Nová verze

    Byla vydána nová verze 19 integrovaného vývojového prostředí (IDE) Qt Creator. Podrobný přehled novinek v changelogu.

    Ladislav Hagara | Komentářů: 0
    12.3. 03:44 | Nová verze

    Bitwig Studio (Wikipedie) bylo vydáno ve verzi 6. Jedná se o proprietární multiplatformní (macOS, Windows, Linux) digitální pracovní stanici pro práci s audiem (DAW).

    Ladislav Hagara | Komentářů: 4
    12.3. 02:11 | Komunita

    Společnost Igalia představila novou linuxovou distribuci (framework) s názvem Moonforge. Jedná se o distribuci určenou pro vestavěné systémy. Vychází z projektů Yocto a OpenEmbedded.

    Ladislav Hagara | Komentářů: 0
    12.3. 00:44 | Nová verze

    Google Chrome 146 byl prohlášen za stabilní. Nejnovější stabilní verze 146.0.7680.71 přináší řadu novinek z hlediska uživatelů i vývojářů. Podrobný přehled v poznámkách k vydání. Opraveno bylo 29 bezpečnostních chyb. Vylepšeny byly také nástroje pro vývojáře.

    Ladislav Hagara | Komentářů: 0
    12.3. 00:22 | Nová verze

    D7VK byl vydán ve verzi 1.5. Jedná se o fork DXVK implementující překlad volání Direct3D 3 (novinka), 5, 6 a 7 na Vulkan. DXVK zvládá Direct3D 8, 9, 10 a 11.

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (16%)
     (7%)
     (0%)
     (12%)
     (29%)
     (2%)
     (5%)
     (1%)
     (13%)
     (24%)
    Celkem 1076 hlasů
     Komentářů: 26, poslední 12.3. 08:56
    Rozcestník

    Dotaz: wait - cekani na všechny procesy

    25.4.2012 16:44 Petr
    wait - cekani na všechny procesy
    Přečteno: 465×
    Dobrý den, prosím vás, mám program(napsaný v C), kde pomocí dvou cyklů vytvářím celkem 10 podřízených procesů (každý cyklus 5). Jak správně napsat funkci wait a kam ji umístit, aby hlavní proces(ten z kterého se vytváří těch 10 dalších) počkal na dokončení všech podřízených procesů a pak pokračoval dál.

    Tedy, aby hlavní proces vytvořil podřízené procesy, počkal až provedou co mají a pak pokračoval dál.

    Děkuji za každou radu.

    Řešení dotazu:


    Odpovědi

    25.4.2012 19:24 petr_p | skóre: 59 | blog: pb
    Rozbalit Rozbalit vše Re: wait - cekani na všechny procesy
    Že by za druhý cyklus?
    25.4.2012 19:28 rastos | skóre: 63 | blog: rastos
    Rozbalit Rozbalit vše Re: wait - cekani na všechny procesy
    No ... teda ... osobnú skúsenosť nemám, ale waitpid() môže čakať na any child process whose process group ID is equal to that of the calling process. Takže ak by každý child process mal to isté process group ID - napr. zhodné s parent PID - čo sa dá tuším dá dosiahnuť tak, že child zavolá setpgid(0,getppid()) a parent zavolá setpgid(0,0) - tak by malo stačiť zavolať waitpid(0,&status,0).

    Daj vedieť, či to zafunguje.
    mess avatar 25.4.2012 23:27 mess | skóre: 43 | blog: bordel | Háj ve Slezsku - Smolkov
    Rozbalit Rozbalit vše Re: wait - cekani na všechny procesy
    Tak z fork() vyleze PID potomka. Takže by mělo stačit si ty PID někde poznačit a pak volat normálně wait(pid) na každý ten PID. Tím se zajistí, že se bude pokračovat, až všchni potomci vychcípou.
    Cez párne mesiace zošíváš vaginy, cez neparne montuješ hajzle.
    26.4.2012 21:03 Petr
    Rozbalit Rozbalit vše Re: wait - cekani na všechny procesy
    Takže si např. ukládat PID všech potomků do pole a potom mít cyklus, kde v každé iteraci bude funkce wait() čekat na ukončení dalšího potomka. Může to takhle fungovat?

    Nebudu problém v tom, že potomci nebudou ukončování v tom pořadí, v kterém byli vytvořeni. Např. vytvořím pět procesů, v hlavním procesu bude cyklus, který bude postupně čekat na ukončení potomků(čeká na 1. na 2. ...čeká na 5.), ale potomci budou ukončení v pořadí např. 3. 1. 2. 5. 4..

    Děkuji za odpověď.
    26.4.2012 21:13 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: wait - cekani na všechny procesy

    A priori to problém není, protože stejně nechcete pokračovat dál, dokud neskončí všichni, a zpoždění dané tím, že pak ještě několikrát zavoláte waitpid() na potomky, kteří už dávno skončili, je zanedbatelné. Na druhou stranu, při téhle metodě vám v systému mohou poměrně dlouho (v závislosti na tom, s jakými odstupy potomci končí) viset zombie, což nepatří k dobrým mravům.

    Osobně bych to řešil spíš tak, že budu v cyklu volat waitpid(-1, …), dokud neskončí všichni potomci. Pokud chcete být opatrný, můžete si potomky "odškrtávat" (udržovat příznak, kdo už skončil), jinak stačí evidovat počet dosud běžících (a čekat, až klesne na nulu).

    V každém případě je ale potřeba dávat pozor na to, že to, že návratová hodnota waitpid() je PID potomka, ještě automaticky neznamená, že potomek opravdu skončil (je potřeba kontrolovat status).

    xkucf03 avatar 27.4.2012 13:54 xkucf03 | skóre: 50 | blog: xkucf03
    Rozbalit Rozbalit vše Re: wait - cekani na všechny procesy
    a zpoždění dané tím, že pak ještě několikrát zavoláte waitpid() na potomky, kteří už dávno skončili, je zanedbatelné.
    A nemůže se stát, že by některý z mých procesů skončil a mezitím se v systému objevil jiný (cizí) se stejným číslem a já pak čekal na něj, což nechci?
    Mám rád, když se lidé přou, znamená to, že vědí, co dělají, a že mají směr. Frantovo.cz, SQL-DK, Relational pipes
    xkucf03 avatar 27.4.2012 13:57 xkucf03 | skóre: 50 | blog: xkucf03
    Rozbalit Rozbalit vše Re: wait - cekani na všechny procesy
    Aha, tak ne :-)
    All of these system calls are used to wait for state changes in a child of the calling process
    Mám rád, když se lidé přou, znamená to, že vědí, co dělají, a že mají směr. Frantovo.cz, SQL-DK, Relational pipes
    mess avatar 27.4.2012 15:33 mess | skóre: 43 | blog: bordel | Háj ve Slezsku - Smolkov
    Rozbalit Rozbalit vše Re: wait - cekani na všechny procesy
    Navíc, dokud nezavoláš wait/waitpid na toho potomka, co chcípnul, tak bude v systému viset jako zombie, takže další proces se stejným PID by se objevit neměl.
    Cez párne mesiace zošíváš vaginy, cez neparne montuješ hajzle.
    27.4.2012 18:14 Petr
    Rozbalit Rozbalit vše Re: wait - cekani na všechny procesy
    Takže, pro 5 vytvořených procesů by mělo fungovat něco jako:

    for(j = 0; j < 5; j++) { waitpid(-1, NULL, 0); }

    Hlavní proces bude čekat, než se ukončí 5 procesů a pak si povalí dál. Vypadá, že to funguje. Co si o tom myslíte?
    27.4.2012 18:39 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: wait - cekani na všechny procesy
    Přečtěte si pozorně poslední odstavec mého předchozího příspěvku. Vy ovšem jdete ještě dál a návratovou hodnotu nekontrolujete vůbec, takže nereagujete správně ani na přerušení signálem nebo jinou chybu.
    27.4.2012 19:09 Petr
    Rozbalit Rozbalit vše Re: wait - cekani na všechny procesy
    Začínám se do toho zamotávat. Mohl by mi někdo napsat, jak správně by ten cyklus měl vypadat, aby počkal na všechny potomky a kontroloval návratovou hodnotu wait() ?
    mess avatar 27.4.2012 21:59 mess | skóre: 43 | blog: bordel | Háj ve Slezsku - Smolkov
    Rozbalit Rozbalit vše Re: wait - cekani na všechny procesy
    Chlape, snaž se trochu. Jako první bych se podíval na manuálové stránky funkce waitpid. Ten cyklus máš +- dobře, jen potřebuješ ošetřit, abys při přerušení signálem neposkočil o 1 dál. Pochybuju, že ti tady někdo napíše přesně, jak to má vypadat. Vypadá to, jako bys chtěl, aby za tebe tady někdo dělal domácí úkol.
    Cez párne mesiace zošíváš vaginy, cez neparne montuješ hajzle.
    26.4.2012 21:48 camel1cz | skóre: 25
    Rozbalit Rozbalit vše Re: wait - cekani na všechny procesy
    DD,

    stačilo trochu zagooglit - řešilo se to na netu, třeba zde

    Obzvlášť se mi líbí ta varianta (jasně, je to bez testů vyjímečných stavů, pádů childů atd.):
    while(wait() > 0) { /* no-op */ ; }
    

    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.