我正在研究一个用C语言编写的用于学校项目的shell,尽管这个问题比你想象的要强得多。问题是当我键入命令时,例如ls
,输出显示在整个shell循环开始时显示的下一个shell>
提示符之后。 shell看起来像:
shell>ls
shell>Debug shell.c
我的代码:
int main(){
char line[255];
while (1){
printf("shell>");
fgets(line, 255, stdin);
if (strcmp(line, "exit\n") == 0){
break;
}
else{
char* args[255];
size_t n = 0;
for (char* ptr = strtok(line, " \n"); ptr; ptr = strtok(NULL, " \n")){
if (n >= 255){
break;
}
args[n++] = ptr;
}
args[n++] = NULL;
for (size_t i = 0; i != n; ++i){
//printf("Token %zu is '%s'.\n", i, args[i]);
}
int pid = fork();
if (pid == 0){
//child process code
int flag = execvp(args[0], args);
if (flag < 0){
perror("execvp failed");
}
}
else{
//parent process code
pid_t wait_pid(pid);
}
}
}
return 0;
}
除了所有其他错误之外,是什么导致输出以这种方式显示?
答案 0 :(得分:0)
pid_t wait_pid(pid);
错误,它不会调用wait_pid
。在调用函数时,您不需要指定返回类型。相反,尝试:
pid_t result_pid = wait_pid(pid);
// add error handling etc here, check man page for return value details
由于您实际上并没有等待子进程,因此父进程会立即打印提示,为您提供所看到的输出。