Непоследовательное чтение строки из трубы - PullRequest
0 голосов
/ 25 декабря 2018

Я читаю некоторые данные из файла и отправляю их по каналу.Когда я читаю данные из канала, иногда внутри появляются дополнительные символы.Дополнительные символы также несовместимы, но обычно это дополнительный «R» в конце.

Данные, которые я прочитал из файла, верны, как всегда и должно быть.Проблемы возникают только после чтения из канала.

Не могли бы вы помочь мне найти ошибку?Я смотрю на это целую вечность и не могу найти его.

Это часть моего кода, которая доставляет мне неприятности.

Спасибо за вашу помощь.

int main (int argc, char **argv) {

    int nClients;
    int file_name_HTML[2];

    create_pipes(file_name_HTML, server_access_request);
    init_free_pipes();

    nClients = getHTMLFilesIntoPipe(file_name_HTML);
    int clients[nClients];

    for(int i=0; i < nClients; i++)
    { 
        if((clients[i] = fork()) == 0) 
        { 
            clientFunction(file_name_HTML, server_access_request);
        } 
    }
    .....
}

int getHTMLFilesIntoPipe(int *file_name_HTML)
{
    int i, n = 0;
    char (*lines)[MAXCHAR] = NULL;
    FILE *fp;
    fp = fopen("./data/listado_html.txt", "r");

    if (!fp) {  /* valdiate file open for reading */
    err_exit("error: file open failed.\n");
    }

    if (!(lines = malloc (MAXLINES * sizeof *lines))) {
    err_exit("error: virtual memory exhausted 'lines'.\n");
    }

    while (n < MAXLINES && fgets (lines[n], MAXCHAR, fp)) /* read each line */
    { 
        char *p = lines[n];                 /* assign pointer  */
        for (; *p && *p != '\n'; p++) {}    /* find 1st '\n'   */
        if (*p != '\n') /* check line read */
        {                   
            int c;  
            while ((c = fgetc (fp)) != '\n' && c != EOF) {} /* discard remainder of line with getchar  */
        }
        *p = 0, n++;    /* nul-termiante   */
    }
    if (fp != stdin) fclose (fp);   /* close file if not stdin */

    for (int i = 0; i < n; i++)
    {
        write(file_name_HTML[WRITE], lines[i], strlen(lines[i]));
    }

    free(lines);

    return n;
}

void clientFunction(int *file_name_HTML, int *server_access_request)
{
    char fileName[MAXCHAR];

    close(file_name_HTML[WRITE]);
    //Read HTML file name
    read(file_name_HTML[READ], fileName, MAXCHAR - 1);
    printf("%s\n", fileName);

    .......
}

Ожидаемый результат: abcd1.html

abcd2.html

abcd3.html

abcd4.html

abcd5.html

Текущий вывод: abcd1.htmlR

abcd2.htmlR

abcd3.htmlR

abcd4.htmlR

abcd5.htmlR

1 Ответ

0 голосов
/ 25 декабря 2018

Это потому, что ваша строка не имеет нулевого (\0) завершения.

Когда вы пишете в канал, исключая нулевой (\0) терминатор.

write(file_name_HTML[WRITE], lines[i], strlen(lines[i])+1);
                                                        ^--- +1 to include null character.

strlen возвращает длину, исключая нулевой терминатор.

...