1

当我在下面运行我的代码并在提示符处输入“ls”时,它会在终端中运行 ls 但然后就坐在那里并且不再打印我的提示符。如何获得控制权以返回父进程?

谢谢

#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");
    }
}
4

1 回答 1

1

答案可能是父进程在启动子进程后立即打印“我已完成” (记住这是一个单独的进程,因此并行运行),然后在子进程甚至开始列出文件之前循环返回以打印提示。如果您向后滚动,您可能会找到下一个提示。

要让父母等待孩子完成,您将不得不使用其中一个wait()功能系列。

于 2011-09-28T02:15:32.427 回答