嘿,我在理解代码失败的地方有点问题。
在执行execvpe(grep)的地方可能会失败(控制台:“grep Error”)。
代码如下:

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

   printf("filter.c\n");

   int fd[2];
   pid_t ls,grep;


   if(argc<3){
    printf("Bitte 2 Argumente angeben <Verzeichnis> <Suchmuster>");
    exit(-1);
   }

   char verzeichnis[256];
   char suchmuster [256];
   char kind       [256];

   strcpy(verzeichnis,argv[1]);
   strcpy(suchmuster ,argv[2]);

   if(pipe(fd)<0){
       printf("Pipe fehlgeschlagen\n");
       return -1;
   }

   if((ls=fork())==-1){
    //fehler
    printf("Fork ls fehlgeschlagen\n");
    exit(-1);
   } else if(ls==0){
    //kind
    printf("\nChild1 laueft(ls)\n");
    if(dup2(fd[1],STDOUT_FILENO)==-1){//dupliziert fd[1]
        printf("Dup failed(ls)\n");
        return -1;
    }

       close(fd[0]);
       close(fd[1]);


       char *argu[]={"-la",verzeichnis,NULL};
       if(execvpe("bin/ls",argu,NULL)==-1){//EXECVE
           printf("ls error");
           return -1;
       }
       return -1    }

   if((grep=fork())==-1){
       //fehler
       printf("Forken von grep fehlgeschlagen\n");
       return -1;
   } else if(grep==0){
       //children2
       printf("Child 2 lauft (grep)\n");
       if(dup2(fd[0],STDIN_FILENO)==-1){
           printf("dup2 fd[0] fehlgeschlagen\n");
           return -1;
       }
       close(fd[0]);
       close(fd[1]);


       char *argu[]={"bin/grep",suchmuster,NULL};
       if(execvpe("bin/grep",argu,NULL)==-1){
           printf("Grep error");
           return -1;
       }
       return -1;
   }
   close(fd[0]);
   close(fd[1]);

   while(wait(NULL)>0);//while()
   return 0;


   //   exit(0);
   }

所以我想在管道上书写和/或阅读有问题。有人知道我的问题吗?:/

最佳答案

如果给定的可执行文件路径包含/字符,则不执行搜索。在这种情况下,如果需要,给定的路径将在调用时相对于进程的当前工作目录进行解析。这很少是一个人想要的,你的案子看起来也不例外。另外,如果您确实要指定二进制文件的路径,而不是简单的名称,那么您将无法从exec的路径搜索变体中获得任何优势。
此外,execvpe()的最后一个参数应该是指向以空结尾的char *数组的第一个元素的指针。尽管指向数组可能除了终结符之外没有其他元素,但我没有发现任何文档允许参数本身是NULL。如果确实要为执行程序指定空环境,则两个execvpe()调用都应采用以下一般形式:

char *argu[] = { "grep", suchmuster, NULL };
char *env[] = { NULL };
if (execvpe("/bin/grep", argu, env) == -1) {

此外,在空环境中执行外部进程是可疑的,尽管不一定是错误的。为此,我看不出有什么优势,您可以使用其中一个exec函数来省去一些麻烦,该函数只向exec映像提供调用进程环境的副本。例如,execvp()将是最接近具有该特性的execvpe()的一个。
此外,将程序参数打包成只用于exec调用的数组似乎有点傻。exec的varargs变体规避了任何这样做的需要(execl(),等等)。
exec函数只在出错时返回。您可以测试返回值,但如果这些函数返回值,则它们的返回值始终为-1。
因此,考虑到所有这些因素,并假设可以提供父进程环境的grepls副本,这是我为您的exec调用建议的一般形式:
       execl("/bin/grep", "grep", suchmuster, NULL);
       // an error occurred
       perror("execing grep");
       _Exit(1);

关于c - 两个 child 执行ls -la | grep使用管道,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/41487502/

10-14 17:28
查看更多