7

我目前在 C 中实现一个 shell。当我尝试运行这样的命令时,我的问题出现了:

SHELL$: sort < txtFile | grep key

sort < txtFile在一个进程(子)中运行,并且在父进程中,即else if(pid > 0)我在管道右侧运行另一个命令。

该程序运行良好,但它退出了我在 main 中设置的无限循环,以继续接收来自用户的输入。

我该如何解决这个问题?

这是我迄今为止处理管道的代码,我没有包括我必须处理重定向的代码:

c2p 是我为此设置的管道。

if(pid == 0)
{
  if( PIPE_FLAG )
    {   
        close(c2p[0]);
        if(dup2(c2p[1], STDOUT_FILENO) == -1){
            perror("dup2() failed");
            exit(2);
        }
    }

    /* Execute command */
    execvp(cmd_args[0], cmd_args);
    perror("exec failed 1. ");          /* return only when exec fails */
    exit(-1);

} 
else if(pid > 0)
{
  if(PIPE_FLAG)
    {
        close(c2p[1]);
        if(dup2(c2p[0], STDIN_FILENO) == -1){
            perror("dup2() failed");
            exit(-1);
        }
        execvp(nxt_args[0], nxt_args);
        perror("exec failed 2. ");          
        exit(-1);    
    }
}
else 
{ 
    /* error occurred */
    perror("fork failed");
    exit(1);
}
4

2 回答 2

3

sort < txtFile在子进程中运行,在父进程中我正在运行管道右侧的命令。

那么你的 shell 进程会发生什么?父进程是shell。通过在父进程中运行右侧命令,您可以让它接管 shell 的进程。请记住 exec() 替换当前进程。

您需要 fork() 两次,并在子进程中执行管道的两侧。父级必须保留 shell,然后等待子级退出,然后再显示下一个命令提示符。

于 2013-11-12T23:17:16.717 回答
0
/*  How shell works */
#include<stdio.h>

#include<unistd.h>

main (int argc, char **argv)
{

  if (argc < 2)
    {

      fprintf (stderr, "\nUsage: ./a.out cmd [options]...\n");

    }

  if (!fork ())
    {

      argv++;

      execvp (argv[0], argv);

    }

}
于 2015-05-10T10:54:34.363 回答