Получение ошибки сегментации на главном / подчиненном - PullRequest
0 голосов
/ 10 октября 2018

Может кто-нибудь объяснить мне, почему я получаю ошибку сегментации в этом коде?Я пытался выяснить это и пустился во время различных поисков.Когда я запускаю код без вызова main (argc, argv), он запускается.Slave преобразует только 2 числа в argv в int, а затем возвращает их.Спасибо.

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

int main(int argc, char* argv[])
{
    int i;
    int* sums;
    sums[argc];
    pid_t cpid;
    int status;
    char* args[10];
    int count = 1;

    for(i = 0; i < (argc / 2); i++) {
        cpid = fork();

        if(cpid == 0) {
            args[1] = argv[count];
            args[2] = argv[count + 1];
            execvp("./slave", args);
        } else {
            waitpid(cpid, &status, 0);
            sums[i] = WEXITSTATUS(status);

            printf("Child returned the number %d\n", sums[i]);
            sprintf(argv[i+1], "%d", sums[i]);
        }
        count += 2;
    }

    if(sums[0] == 0) {
        printf("done\n");
    } else {
        main(argc/2, args);
    }
}

1 Ответ

0 голосов
/ 10 октября 2018

Первая проблема заключается в том, что вы не выделили память для sums, а sums[i] получает доступ к мусорному местоположению.сделать это:

 int sums[argc];

Во-вторых, для execvp массив аргументов функции должен иметь 1. [0] - допустимая строка.2. последний элемент [3] должен иметь значение NULL

       args[0] = "some-execution-file-name";
       args[1] = argv[count];
       args[2] = argv[count + 1];
       args[3] = NULL;

В противном случае функция не имеет представления о размере массива, и подчиненный может умереть, пытаясь прочитать элемент [0].

...