Обработчик сигналов SIGCHLD

Код не работает, и он зацикливается. Я думаю, что ошибка в методе gestore, который является обработчиком сигналов SIGCHLD. Это первый раз, когда я использую обработчик для захвата сигналов SIGCHLD. Эта программа продолжает извлекать случайно от 0 до argv[1], пока число не появится в argv[1] раз. Если не ясно, можете ли вы проверить мою старую программу, которую я поставил в конце вопроса. Можете ли вы помочь мне найти ошибку?

#include <stdio.h>
#include <stdlib.h>
#include <sys/types.h>
#include <sys/wait.h>
#include <errno.h>
#include <string.h>
#include <unistd.h>
#include <signal.h>

int a;
void gestore(int segnale);
int main(int argc, char * argv[]){
    int n = atoi(argv[1]), i, pid;
    int * vec;
    vec = malloc((n+1)*sizeof(*vec));
    memset (vec, 0, sizeof(*vec));
    char * newargv[] = {argv[0], argv[1] , NULL};
    for(i = 0; i < n; i++){
        pid = fork();
        if (pid == 0)
            execve("./throw-dice", newargv, NULL);
        signal(SIGCHLD, gestore);
        vec[WEXITSTATUS(a)]++;
    }
    while(vec[i] != n){
        for(i = 1; i < n+1 && vec[i] != n; i++){
            if(vec[i] != 0){
                pid = fork();
                if (pid == 0)
                    execve("./throw-dice", newargv, NULL);
                signal(SIGCHLD, gestore);
                vec[WEXITSTATUS(a)]++;
            }
        }
    }
    printf("The value %d is appeared %d times!\n", i, vec[i]);
    while (wait(&a) != -1);
    free(vec);
}

void gestore(int segnale){
    signal(segnale, SIG_IGN);
    waitpid(WAIT_ANY, &a, WNOHANG);
    signal(segnale, gestore);
}

Моя цель состояла в том, чтобы изменить мою старую программу (которая работает), изменяя способ, которым я фиксирую выходной статус childs. От синхронного с "ожиданием" асинхронного с помощью метода gestore, который обрабатывает сигналы SIGCHLD. Это моя старая программа:

#include <stdio.h>
#include <stdlib.h>
#include <sys/types.h>
#include <sys/wait.h>
#include <errno.h>
#include <string.h>
#include <unistd.h>

int main(int argc, char * argv[]){
    int n = atoi(argv[1]), a, i, pid;
    int * vec;
    vec = malloc((n+1)*sizeof(*vec));
    memset (vec, 0, sizeof(*vec));
    char * newargv[] = {argv[0], argv[1] , NULL};
    for(i = 0; i < n; i++){
        pid = fork();
        if (pid == 0)
            execve("./throw-dice", newargv, NULL);
        wait(&a);
        vec[WEXITSTATUS(a)]++;
    }
    while(vec[i] != n){
        for(i = 1; i < n+1 && vec[i] != n; i++){
            if(vec[i] != 0){
                pid = fork();
                if (pid == 0)
                    execve("./throw-dice", newargv, NULL);
                wait(&a);
                vec[WEXITSTATUS(a)]++;
            }
        }
    }
    printf("The value %d is appeared %d times\n", i, vec[i]);
    while (wait(&a) != -1);
    free(vec);
}

//throw-dice.c

#include <unistd.h>
#include <stdio.h>
#include <stdlib.h>

int main(int argc, char * argv[]) {
    int n, val;
    // Must have an argument
    if (argc < 2) {
        exit(-1);
    }
    // the 1st argument must be a positive number
    if ((n = atoi(argv[1])) <= 0) {
        exit(-1);
    }
    //  sleep(1); // sleep a bit
    srand(getpid()); // initialize the random seed with PID
    val = rand() % n + 1;
    printf("(PID=%d): got number %d\n", getpid(), val);
    exit(val);
}

0 ответов

Другие вопросы по тегам