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 11:55 | Humor

    Microsoft poskytl FBI uživatelské šifrovací klíče svého nástroje BitLocker, nutné pro odemčení dat uložených na discích třech počítačů zabavených v rámci federálního vyšetřování. Tento krok je prvním známým případem, kdy Microsoft poskytl klíče BitLockeru orgánům činným v trestním řízení. BitLocker je nástroj pro šifrování celého disku, který je ve Windows defaultně zapnutý. Tato technologie by správně měla bránit komukoli kromě

    … více »
    NUKE GAZA! 🎆 | Komentářů: 32
    včera 01:44 | Komunita

    Spotify prostřednictvím svého FOSS fondu rozdělilo 70 000 eur mezi tři open source projekty: FFmpeg obdržel 30 000 eur, Mock Service Worker (MSW) obdržel 15 000 eur a Xiph.Org Foundation obdržela 25 000 eur.

    Ladislav Hagara | Komentářů: 3
    23.1. 18:11 | Zajímavý software

    Nazdar! je open source počítačová hra běžící také na Linuxu. Zdrojové kódy jsou k dispozici na GitHubu. Autorem je Michal Škoula.

    Ladislav Hagara | Komentářů: 3
    23.1. 16:55 | Nová verze

    Po více než třech letech od vydání verze 1.4.0 byla vydána nová verze 1.5.0 správce balíčků GNU Guix a na něm postavené stejnojmenné distribuci GNU Guix. S init systémem a správcem služeb GNU Shepherd. S experimentální podporou jádra GNU Hurd. Na vývoji se podílelo 744 vývojářů. Přibylo 12 525 nových balíčků. Jejich aktuální počet je 30 011. Aktualizována byla také dokumentace.

    Ladislav Hagara | Komentářů: 9
    23.1. 15:44 | Zajímavý software

    Na adrese gravit.huan.cz se objevila prezentace minimalistického redakčního systému GravIT. CMS je napsaný ve FastAPI a charakterizuje se především rychlým načítáním a jednoduchým ukládáním obsahu do textových souborů se syntaxí Markdown a YAML místo klasické databáze. GravIT cílí na uživatele, kteří preferují CMS s nízkými nároky, snadným verzováním (např. přes Git) a možností jednoduchého rozšiřování pomocí modulů. Redakční

    … více »
    2012 | Komentářů: 0
    23.1. 12:55 | Zajímavý software

    Tým Qwen (Alibaba Cloud) uvolnil jako open-source své modely Qwen3‑TTS pro převádění textu na řeč. Sada obsahuje modely VoiceDesign (tvorba hlasu dle popisu), CustomVoice (stylizace) a Base (klonování hlasu). Modely podporují syntézu deseti různých jazyků (čeština a slovenština chybí). Stránka projektu na GitHubu, natrénované modely jsou dostupné na Hugging Face. Distribuováno pod licencí Apache‑2.0.

    NUKE GAZA! 🎆 | Komentářů: 0
    23.1. 01:11 | Nová verze

    Svobodný citační manažer Zotero (Wikipedie, GitHub) byl vydán v nové major verzi 8. Přehled novinek v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 0
    22.1. 16:55 | Nová verze

    Byla vydána verze 1.93.0 programovacího jazyka Rust (Wikipedie). Podrobnosti v poznámkách k vydání. Vyzkoušet Rust lze například na stránce Rust by Example.

    Ladislav Hagara | Komentářů: 0
    22.1. 14:00 | Komunita

    Svobodný operační systém ReactOS (Wikipedie), jehož cílem je kompletní binární kompatibilita s aplikacemi a ovladači pro Windows, slaví 30. narozeniny.

    Ladislav Hagara | Komentářů: 8
    22.1. 11:00 | IT novinky

    Společnost Raspberry Pi má nově v nabídce flash disky Raspberry Pi Flash Drive: 128 GB za 30 dolarů a 256 GB za 55 dolarů.

    Ladislav Hagara | Komentářů: 2
    Které desktopové prostředí na Linuxu používáte?
     (18%)
     (5%)
     (0%)
     (10%)
     (22%)
     (3%)
     (5%)
     (2%)
     (11%)
     (34%)
    Celkem 609 hlasů
     Komentářů: 17, poslední 22.1. 15:24
    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: 2246×
    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: 71 | 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.