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í
×
    včera 18:33 | Nová verze

    Byla vydána (𝕏) nová verze 24.7 open source firewallové a routovací platformy OPNsense (Wikipedie). Jedná se o fork pfSense postavený na FreeBSD. Kódový název OPNsense 24.7 je Thriving Tiger. Přehled novinek v příspěvku na fóru.

    Ladislav Hagara | Komentářů: 0
    včera 05:11 | Bezpečnostní upozornění

    Binarly REsearch upozorňuje na bezpečnostní problém PKFail (YouTube) v ekosystému UEFI. Stovky modelů zařízení používají pro Secure Boot testovací Platform Key vygenerovaný American Megatrends International (AMI) a jeho privátní část byla při úniku dat prozrazena. Do milionů zařízení (seznam v pdf) po celém světě tak útočníci mohou do Secure Bootu vložit podepsaný malware. Otestovat firmware si lze na stránce pk.fail. Ukázka PoC na Linuxu na Windows na YouTube.

    Ladislav Hagara | Komentářů: 11
    včera 02:22 | Nová verze

    Mobilní operační systém /e/OS (Wikipedie) založený na Androidu / LineageOS, ale bez aplikací a služeb od Googlu, byl vydán ve verzi 2.2 (Mastodon, 𝕏). Přehled novinek na GitLabu. Vypíchnuta je rodičovská kontrola.

    Ladislav Hagara | Komentářů: 2
    včera 01:22 | IT novinky

    Společnost OpenAI představila vyhledávač SearchGPT propojující OpenAI modely umělé inteligence a informace z webů v reálném čase. Zatím jako prototyp pro vybrané uživatele. Zapsat se lze do pořadníku čekatelů.

    Ladislav Hagara | Komentářů: 0
    včera 00:11 | Nová verze

    Distribuce Linux Mint 22 „Wilma“ byla vydána. Je založená na Ubuntu 24.04 LTS, ale s desktopovým prostředím Cinnamon (aktuálně verze 6.2), příp. MATE nebo Xfce, balíkem aplikací XApp, integrací balíčků Flatpak a dalšími změnami. Více v přehledu novinekpoznámkách k vydání.

    Fluttershy, yay! | Komentářů: 2
    25.7. 17:44 | Zajímavý článek Ladislav Hagara | Komentářů: 2
    25.7. 17:22 | Nová verze

    Byla vydána nová verze 14 integrovaného vývojového prostředí (IDE) Qt Creator. Podrobný přehled novinek v cgitu. Vypíchnout lze podporu rozšíření v Lua.

    Ladislav Hagara | Komentářů: 0
    25.7. 17:11 | Nová verze

    Byla vydána verze 1.80.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
    25.7. 14:11 | IT novinky

    Apple oznámil, že v beta verzi spustil své Apple Maps na webu. Podporován je také webový prohlížeč Chrome. Ne však na Linuxu.

    Ladislav Hagara | Komentářů: 23
    25.7. 13:11 | IT novinky

    Portál Stack Overflow po roce opět vyzpovídal své uživatele, jedná se především o vývojáře softwaru, a zveřejnil detailní výsledky průzkumu. Průzkumu se letos zúčastnilo více než 65 tisíc vývojářů. Z Česka jich bylo 710. Ze Slovenska 246.

    Ladislav Hagara | Komentářů: 0
    Rozcestník

    Dotaz: C - SIGUSR1 pomocí kill a sigaction

    24.11.2014 20:43 BamBam
    C - SIGUSR1 pomocí kill a sigaction
    Přečteno: 308×
    Vytvářím program , který vytvoří dva procesy, které propojuji rourou. První potomek přesměruje svůj výstup do roury a bude do něj zapisovat dvojice náhodných čísel oddělené mezerou. Mezi zápisy čísel mám prodlevu 1 sekundu. Druhý potomek přesměruje výstup roury na svůj standardní vstup, přesměruje svůj výstup do souboru s názvem out.txt.

    Chci udělat, aby rodičovský proces počkal 5 sekund a poté poslal signál SIGUSR1 prvnímu procesu (generátoru čísel) pomocí kill, což způsobí korektní ukončení obou procesů. Počká na ukončení procesů a poté se ukončí.

    Ale nevím jakým způsobem v prvním procesu ošetřit signál SIGUSR1 pomocí sigaction, tak aby po přijmutí signálu, vypsal něco na svůj chybový výstup a ukončil se.

    #define NAZEV "out.txt"

    int main() { FILE *soubor; soubor = fopen(NAZEV, "a+");

    int roura[2]; pipe(roura);

    pid_t pid1; int retcode; pid1=fork(); if(pid1 == 0) // potomek1 { close(roura[0]); printf("Potomek1...\n"); dup2(roura[1], STDOUT_FILENO); // presmerovani výstupu do roury

    int i = 0; while(i < 6) { i++; int a = rand(); int b = rand(); sleep(1); printf("%d %d\n", a, b); } close(roura[1]); exit(45);

    } else if (pid1 < 0) { printf("Fork selhal\n"); exit(2); } else { pid_t pid2; pid2 = fork(); if (pid2 == 0) //potomek 2 { close(roura[1]);

    /*presmerovani výstup roury na svůj standardní vstup */ dup2(roura[0], STDIN_FILENO);

    printf("Potomek2...\n"); int i = 0; while(i < 5) { i++; int c; int d; scanf("%d %d", &c, &d); printf("%d %d\n", c, d); fprintf(soubor,"%d %d\n", c, d); }

    printf("Potomek2 skoncil\n"); exit(0); } else if (pid2 < 0) { printf("Fork selhal\n"); exit(2); }else { sleep(5]; kill(pid1, SIGUSR1); wait(&pid1); //ceka na potomka1 wait(&pid2); //ceka na potomka2 printf("Rodic konci\n"); exit(0); } } exit(0); }

    Řešení dotazu:


    Odpovědi

    24.11.2014 20:52 BamBam
    Rozbalit Rozbalit vše Re: C - SIGUSR1 pomocí kill a sigaction

    #define NAZEV "out.txt"

    int main()
    {
    FILE *soubor;
    soubor = fopen(NAZEV, "a+");
    int roura[2];
    pipe(roura);
    pid_t pid1;
    int retcode;
    pid1=fork();
    if(pid1 == 0) // potomek1
    {
    close(roura[0]);
    printf("Potomek1...\n");
    dup2(roura[1], STDOUT_FILENO); // presmerovani výstupu do roury
    int i = 0;
    while(i < 6)
    {
    i++;
    int a = 2 + i;
    int b = 4 + i;
    sleep(1);
    printf("%d %d\n", a, b);
    }
    close(roura[1]);
    exit(45);
    } else if (pid1 < 0)
    {
    printf("Fork selhal\n");
    exit(2);
    } else
    {
    pid_t pid2;
    pid2 = fork();
    if (pid2 == 0) //potomek 2
    {
    close(roura[1]);
    dup2(roura[0], STDIN_FILENO); //presmerovani výstup roury na svůj standardní vstup
    printf("Potomek2...\n");
    int i = 0;
    while(i < 5)
    {
    i++;
    int c;
    int d;
    scanf("%d %d", &c, &d);
    printf("%d %d\n", c, d);
    fprintf(soubor,"%d %d\n", c, d);
    }
    printf("Potomek2 skoncil\n");
    exit(0);
    } else if (pid2 < 0)
    {
    printf("Fork selhal\n");
    exit(2);
    }else
    { wait(&pid1); //ceka na potomka1
    wait(&pid2); //ceka na potomka2 
    printf("Rodic konci\n");
    exit(0);
    }
    }
    exit(0);
    }

    24.11.2014 22:34 Sten
    Rozbalit Rozbalit vše Re: C - SIGUSR1 pomocí kill a sigaction
    Váš kód v sigaction někam poznamená, že přišel signál. Ten proces bude v tu dobu nejspíš viset na sleep, který příchozí signál přeruší s EINTR, ale nemusí, takže je vhodné to otestovat i před tím sleepem. Stačí se pak podívat, jestli byl poznamenán příchod signálu, a pokud ano, tak proces ukončit. Pokud nepotřebujete po přerušení uklidit, tak ukončit proces jde i ze sigaction pomocí _exit().

    Mimochodem pokud potřebujete zastavit zapisující proces ze čtecího, stačí ve čtecím procesu tu rouru zavřít. Zapisovací proces pak při pokusu o zápis dostane SIGPIPE.

    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.