2011-09-28 40 views
1

当我运行我的代码下面,并在提示符下键入“ls”时,它在终端中运行ls,但只是坐在那里,并没有再次打印我的提示。我如何获得控制权回到父流程?fork/execvp控制没有返回到父母

感谢

#include <stdio.h> 
#include <string.h> 
#include <unistd.h> 

int main(int argc, char* argv[]){ 
    while(1){ 
     print_the_prompt(); 
     char user_text[100]; 
     if(fgets(user_text, sizeof(user_text), stdin) != NULL){ 
      char* nl_char = strchr(user_text, '\n'); 
      if(nl_char != NULL){ 
       *nl_char = '\0'; 
      } 
     } 

    //printf("user_text = \"%s\"\n", user_text); 

     if(is_command_built_in(user_text)){ 
      //run built in command 
     } 
     else{ 
      //run regular command 
      execute_new_command(user_text); 
     } 
    } 

    return 0; 
} 

void print_the_prompt(){ 
     printf("!: "); 
} 

int is_command_built_in(char* command){ 
    return 0; 
} 

void execute_new_command(char* command){ 
    pid_t pID = fork(); 
    if(pID == 0){ 
     //is child 
     char* execv_arguments[] = { command, (char*)0 }; 
     execvp(command, execv_arguments); 
    } 
    else{ 
     //is parent 
     printf("im done"); 
    } 
} 

回答

1

答案很可能是父打印“即时完成” 开始孩子(记住它是一个独立的过程,因此在并行运行)后,然后循环回绕到在孩子开始列出文件之前打印提示。如果你回滚你可能会发现你的下一个提示。

要让父母等待孩子完成,必须使用wait()系列函数之一。

+0

oooooh ok。我不知道wait()。我会研究这一点。你是对的,它打印出“我完成了”,然后从ls打印出来。 – james

相关问题