abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 04:33 | Bezpečnostní upozornění

    Byla vydána verze 0.81 telnet a ssh klienta PuTTY. Opravena je kritická bezpečnostní chyba CVE-2024-31497 obsažena ve verzích 0.68 až 0.80. Používáte-li klíč ECDSA NIST P521 a použili jste jej v PuTTY nebo Pageantu, považujte jej za kompromitovaný.

    Ladislav Hagara | Komentářů: 0
    včera 21:44 | Komunita

    Hra MineClone2 postavena nad voxelovým herním enginem Minetest byla přejmenována na VoxeLibre.

    Ladislav Hagara | Komentářů: 0
    včera 19:11 | IT novinky

    Společnosti Avast Software s.r.o. byla pravomocně uložena pokuta ve výši 351 milionů Kč. Tu uložil Úřad pro ochranu osobních údajů za neoprávněné zpracování osobních údajů uživatelů jejího antivirového programu Avast a jeho rozšíření internetových prohlížečů (Browser Extensions), k čemuž docházelo prokazatelně po část roku 2019.

    … více »
    Ladislav Hagara | Komentářů: 1
    včera 15:55 | Zajímavý článek

    Bylo vydáno do češtiny přeložené číslo 714 týdeníku WeeklyOSM přinášející zprávy ze světa OpenStreetMap.

    Ladislav Hagara | Komentářů: 0
    včera 15:44 | Pozvánky

    V sobotu 20. dubna lze navštívit Maker Faire Jihlava, festival plný workshopů, interaktivních činností a především nadšených a zvídavých lidí.

    Ladislav Hagara | Komentářů: 0
    včera 14:44 | Zajímavý software

    Knihovna pro potlačení šumu RNNoise byla vydána ve verzi 0.2. Kvalitu potlačení lze vyzkoušet na webovém demu.

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

    FRRouting (FRR) (Wikipedie), tj. softwarová sada pro směrování síťové komunikace, fork Quagga, byl vydán ve verzi 10.0.

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

    Julian Andres Klode vydal APT (Advanced Packaging Tool) ve verzích 2.9.0 a 2.9.1. Jedná se o vývojové verze nové větve APT 3.0. Vylepšuje se uživatelské rozhraní. Přidány byly barvičky. Aktuální náhledy a vývoj lze sledovat na Mastodonu.

    Ladislav Hagara | Komentářů: 3
    14.4. 17:00 | Komunita

    Miguel de Icaza se na svém blogu rozepsal o vložitelných herních enginech. Kdysi slibné projekty UrhoSharp a Urho3D jsou již mrtvé. Zůstává Godot. Aktuálně vývojáři řeší Pull request #90510 s návrhem knihovny LibGodot.

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

    Byla vydána nová verze 5.0 linuxové distribuce Lakka, jež umožňuje transformovat podporované počítače v herní konzole. Nejnovější Lakka přichází s RetroArchem 1.17.0.

    Ladislav Hagara | Komentářů: 0
    KDE Plasma 6
     (60%)
     (13%)
     (2%)
     (25%)
    Celkem 404 hlasů
     Komentářů: 4, poslední 6.4. 15:51
    Rozcestník

    Dotaz: C, nebo C++ a fork

    26.3.2007 20:00 filbar | skóre: 36 | blog: Denicek_programatora | Ostrava
    C, nebo C++ a fork
    Přečteno: 2211×
    Nevíte někdo jak vytvořit v C/C++ fork tak, aby jeden rodič měl dva potomky? Zkouším to na něčem jako toto:
    #include <stdio.h>
    #include <sys/types.h>
    #include <unistd.h>
    #include <sys/wait.h>
    
    
    int main() {
            int roura[2];
            pipe(roura);
            int pid=fork();
    
            if(pid != 0) { // rodic
                    close(roura[0]);
                    int a = 10;
                    write(roura[1],&a,sizeof(a));
    //              close(roura[1]);
                    printf("PID rodice: %d\n", getpid());
                    printf("Potomek: %d\n", pid);
                    int pid1=fork();
                    if (pid1 == 0) {
                            int b = 312;
                            write(roura[1],&b,sizeof(b));
                            close(roura[1]);
                            printf("Potomek2-PID rodice: %d\n", getpid());
                            printf("Potomek2-Potomek: %d\n", pid);
                    }
            } else { // potomek
                    close(roura[1]);
                    int a1, b1;
                    read(roura[0],&a1,sizeof(a1));
                    read(roura[0],&b1,sizeof(b1));
                    close(roura[1]);
                    printf("PID potomka: %d\n", getpid());
                    printf("Potomek: %d\n", pid);
                    printf("Soucet císel z roury je %d\n", a1 + b1);
            }
            return 0;
    }
    
    Roury mi fungují, ale nějak mi nesouhlasí PIDY:
    PID rodice: 11731
    Potomek: 11732
    Potomek2-PID rodice: 11733
    Potomek2-Potomek: 11732
    PID potomka: 11732
    Potomek: 0
    Soucet císel z roury je 322
    
    To vypadá jako by měl jeden potomek více rodičů?! Jak to má být správně?

    Odpovědi

    Luboš Doležel (Doli) avatar 26.3.2007 20:55 Luboš Doležel (Doli) | skóre: 98 | blog: Doliho blog | Kladensko
    Rozbalit Rozbalit vše Re: C, nebo C++ a fork
    Máte tam řádný bordel v proměnných, v té větvi s pid1 používáte pid. A navíc v té větvi máte blbě podmínku (pid1 == 0).
    26.3.2007 21:04 Michal Kubeček | skóre: 72 | Luštěnice
    Rozbalit Rozbalit vše Re: C, nebo C++ a fork
    Výsledek přesně odpovídá tomu, co jste naprogramoval. První tučný řádek vám ukáže PID původního procesu, druhý tučný řádek PID druhého potomka.

    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.