c管道,stdin / stdout和排序

时间:2012-02-01 08:12:01

标签: c linux stdout pipe stdin

我试图编写一个程序,分叉并发送sort(linux)一些单词来排序stdin,因为没有args的sort将使用stdin。然后从父级的sort中收集stdout以输出父级的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 个答案:

答案 0 :(得分:1)

我认为排序期望stdin不会被终止:如果从文件重定向则不会。

然而,确实需要知道输入何时完成(并且直到输入完成才会发出任何内容,因此您的读取将被阻止)。写完之后尝试关闭fo[1]

哦,你可以在strace -f下运行它来看看发生了什么,它会告诉你父进程和子进程正在做什么。