Почему здесь дочерний процесс ничего не печатает?

Предположим, что все переменные были объявлены ранее ... потому что они были. Дочерний процесс ничего не печатает, что заставляет меня думать, что он не выполняется. Родительский процесс работает нормально, хотя и не получает разделяемую память. Прошу прощения за длину этого кода ...

// create 5 child process
for(int k=0;k<5;k++){

    // fork a child process
    pid = fork();

    // error occured on fork
    if (pid < 0) {
        fprintf(stderr, "Fork Failed");
        return 1;
    }
    // this is what the child process will run
    else if (pid == 0) {
        //create a shared mem segment
        segment_id = shmget(IPC_PRIVATE, size, S_IRUSR | S_IWUSR);

        //attach the shared memory segment
        shared_memory = (char *) shmat(segment_id, NULL, 0);

        printf("this is child");

        double x = 0;
        double sum = 0;

        // Run process that sums the function
        for(int i=0; i<n; i++){
            // get random number in range of x1-x2
            x = rand()%(x2 - x1 + 1) + x1;
            sum = sum + f(x);
        }

        //write output to the shared memory segment
        sprintf(shared_memory, "%f", sum);
        execlp("/bin/ls", "ls", NULL);

     }

    // this is what the parent process will run
    else {

       //print output from shared memory
        printf("\n*%s", shared_memory);

        //detach shared memory
        shmdt(shared_memory);

        //Here we add the shared memory to the array
        // To add together at the end
        // but since I cant get the memory to share
        // the array can't be implemented

        //remove the shared memory segment
        shmctl(segment_id, IPC_RMID, NULL);

        wait(NULL);
    }
} // End of for statement

Ответов (3)

Решение

Поток C stdout выполняет внутреннюю буферизацию данных. Вероятно, ваше сообщение «this is child» буферизуется, и буфер не очищается execlp, поэтому он просто исчезает. Попробуйте fflush(stdout); после printf. Между прочим, вы должны сделать это и до fork(), чтобы дочерний и родительский оба не пытались записать вывод, буферизованный до вилки.

Сначала избавьтесь от всей общей памяти и затем посмотрите, сможет ли дочерний процесс успешно выполнить printf.

Судя по этому фрагменту, вы инициализируете shared_memory в дочернем процессе, но не в родительском процессе.

Печать в stderr не буферизуется.

fprintf(stderr,"Plop\n");

Кроме того, общая память (segment_id, shared_memory) не инициализируется в родительском элементе (или, если это так, то это не то же самое, что и дочерний элемент).

Кроме того, родительский элемент потенциально разрушает общую память, пока дочерний элемент все еще обрабатывает. Родитель должен сначала подождать, а затем обработать данные, созданные дочерним элементом.