c трубы, стандартный вывод / сортировка и сортировка - PullRequest
6 голосов
/ 01 февраля 2012

Я пытаюсь написать программу, которая разветвляет и отправляет sort (linux) некоторые слова для сортировки по stdin, так как для сортировки без аргументов будет использоваться stdin.Затем соберите stdout из sort в parent для вывода на stdout родителя.

В настоящее время моя программа зависает.Может ли кто-нибудь помочь мне объяснить, что происходит?

Мой код:

#include <stdio.h>
#include <stdlib.h>
#include <fcntl.h>
#include <sys/stat.h>
#include <string.h>
#include <errno.h>
#include <unistd.h>


int main(int argc, char *argv[]){
    int fi[2];
    int fo[2];
    int oldstdin;
    int oldstdout;

    if (pipe(fi) == -1){
        exit(EXIT_FAILURE);
    }
    if (pipe(fo) == -1){
        exit(EXIT_FAILURE);
    }
    oldstdin = dup(STDIN_FILENO); /* Save current sdtin */
    oldstdout = dup(STDOUT_FILENO); /* Save current stdout */

    close(STDIN_FILENO);
    close(STDOUT_FILENO);


    if(dup2 (fo[0],STDIN_FILENO) == -1) /* Make the read end of out to be stdin */
        exit(EXIT_FAILURE);
    if(dup2 (fi[1],STDOUT_FILENO) == -1) /* Make the write end of in to be stdout */
        exit(EXIT_FAILURE);


    switch(fork()){
    case -1:
        exit(EXIT_FAILURE);
    case 0: /* CHILD */  
        close(fo[0]);
        close(fo[1]);
        close(fi[0]);
        close(fi[1]);
        execlp("sort","sort", (char *)NULL);
    default:
        break; /* fall through to parent */
    }

    char input[100];
    close(STDIN_FILENO);
    close(STDOUT_FILENO);
    dup2(oldstdin,STDIN_FILENO);
    dup2(oldstdout,STDOUT_FILENO);

    close(fo[0]); /* these are used by CHILD */
    close(fi[1]); /* "" */

    write(fo[1],"dino\nbat\nfish\nzilla\nlizard\0",27);
    input[read(fi[0], input,100)] = 0;
    printf("%s", input);
}

1 Ответ

1 голос
/ 01 февраля 2012

Я не думаю, что сортировка ожидает, что stdin будет завершено нулем: это не произойдет, если перенаправить из файла.

Однако необходимо знать, когда ввод завершен (и не будет ничего излучать, пока он не завершится, поэтому ваше чтение будет блокироваться). Попробуйте закрыть fo[1] после записи в него.

О, и вы можете запустить это под strace -f, чтобы увидеть, что происходит, и он покажет вам, что делают и родительский, и дочерний процессы.

...