Труба: плохие файловые дескрипторы - PullRequest
2 голосов
/ 18 марта 2019

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

Я изучаю многопроцессорное взаимодействие с использованием pipe, я столкнулся с этой ошибкой, называемой плохими дескрипторами файлов, я не понимаю, почему в моем коде есть эта ошибка.

#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <sys/wait.h>
#include <string.h>
#define SIZE 50

struct record {
    int freq;
    char word[SIZE];
};

int main(){

int number_process = 3;
int pipes[number_process][2];

struct record r1;
r1.freq = 10;
strcpy(r1.word, "Cat");

struct record r2;
r2.freq = 20;
strcpy(r2.word, "Elephant");

struct record r3;
r3.freq = 30;
strcpy(r3.word, "Dragon");

struct record records_array[3] = {r1, r2, r3}; 

for (int i = 0; i < number_process; i++){

    if (pipe(pipes[i]) == -1){
        perror("pipe");
        exit(1);
    }

    // Create children.
    pid_t fork_result = fork();
    if (fork_result == -1){
        perror("Parent fork");
        exit(1);
    } else if (fork_result == 0){

        if (close(pipes[i][0]) == -1){
            perror("Child closes reading port");
            exit(1);
        }

        // Later children is going to close all reading port from pipe that parent creates.
        for (int child_no = 0; child_no < i; child_no++) {
            if (close(pipes[child_no][0]) == -1) {
                perror("close reading ends of previously forked children");
                exit(1);
            }
        }

        // Now, I am trying to write each strct record member from the above array into the pipe
        // when I run the program, it won't allow me to do so because of bad file descriptor exception.
        for (int j = 0; j < number_process; i++){
            if (write(pipes[i][1], &(records_array[j]), sizeof(struct record)) == -1){
                perror("write from child to pipe");
                exit(1);
            }
        }

        // Finishing writing, close the writing end in pipe.
        if (close(pipes[i][1]) == -1){
            perror("Child closes writing port");
            exit(1);
        }
        // Terminate the process.
        exit(0);

    } else {
        // Parent is closing all the writing ends in pipe.
        if (close(pipes[i][1]) == -1){
            perror("Parent close writing");
            exit(1);
        }

    }

}
    return 0;

}

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

Я чувствую себя полностью растерянным в этой концепции записи и передачи. Может кто-нибудь любезно объяснить мне, что я где-то сделал неправильно?

1 Ответ

0 голосов
/ 18 марта 2019

Ваша проблема не имеет никакого отношения к системным вызовам, которые вы используете. Это более обыденно. for (int j = 0; j < number_process; i++) это ошибка. Вы используете i для доступа к массиву файловых дескрипторов и неправильно увеличиваете его. Вы хотели увеличить j.

...