С-сигналы не работают правильно - PullRequest
0 голосов
/ 25 мая 2018

Я столкнулся с ошибкой следующего кода.Он выполняет только тот обработчик, который связан с нечетными числами (в случае, если родитель создает нечетное случайное число, включенное между 1 и 10), в то время как одно для четного всегда "немой".Может ли кто-нибудь мне помочь?

#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>
#include <sys/msg.h>
#include <sys/types.h>
#include <signal.h>
#include <math.h>

pid_t pid1,pid2;
int r, ric1, ric2;
int fd[4];  //per 2 processi figli

void handler_one(){
    read(fd[0], &ric1, sizeof(int));
    printf("Im the first child process...the even received numebr is...%d\n", ric1);
    sleep(1);
}

void handler_two(){
    read(fd[2], &ric2, sizeof(int));
    printf("I'm the second child process...the odd receiver number is...%d\n", ric2);
    sleep(1);
}

void main(){


    pipe(fd);
    pipe(fd+2);

    pid1=fork();
    if(pid1)
        pid2=fork();

    while(1){
        if(pid1<0 || pid2<0){
            perror("AN ERROR OCCURRED!!!!!!!\n");
            exit(1);
        }
        else if(!pid1 && pid2){ //child #1
            signal(SIGUSR1, handler_one);
        }
        else if(pid1 && !pid2){ //child #2
            signal(SIGUSR2, handler_two);
        }
        else{   //padre
            printf("I'm the parent and I'm gonna send a random number\n");
            r=rand()%10+1;
            if(r%2==0){
                write(fd[1], &r, sizeof(int));
                kill(pid1, SIGUSR1);
            }               
            else{
                write(fd[3], &r, sizeof(int));
                kill(pid2, SIGUSR2);
            }
            sleep(1);
        }

    }
}

1 Ответ

0 голосов
/ 25 мая 2018

Ваше условие для настройки обработчика сигнала дочернего элемента 1 неверно.Вместо

   else if(!pid1 && pid2){ //child #1

это должно быть

   else if(!pid1 && !pid2){ //child #1

Не уверен, что если вам гарантировано, что pid1 и pid2 инициализированы нулем, вы можете сделать это явно.

...