小壳背景
Minishell background
我正在为大学做一个minishell项目,我不知道如何在后台执行命令。我知道的一件事是我必须使用 waitpid() 和 sigaction(),但我不知道如何使用。如果有人愿意帮助我,我将不胜感激。这是我使用的部分代码,用于使用 minishell 命令。
void execute_command_line(command* cmds, int n){
pid_t id,pid;
int status;
id=fork();
if(id==-1){
exit(EXIT_FAILURE);
}
else if(if==0){
execvp(cmds[0] . argv[0],&cmds[0] .argv[0]);
exit(0);
}
else{
pid=wait(&status);
if(pid==-1){
perror("Father: an error has ocurred.\n");
exit(EXIT_FAILURE);
}
else if(pid==id){
printf("Father: the son has ended.\n");
}
}
}
后台进程的一个关键特征是您无法与其交互(但它仍然可以打印到您的终端)。这至少意味着键盘生成的信号不得传递给该进程。
这可以通过调用 setsid() 创建一个新会话来完成,或者可以通过简单地禁用子进程中的键盘信号来模拟(有你的 sigaction)。
使用 waitpid 意味着您的父级可能不会立即退出,而是会等待(使用 waitpid)后台子级完成。
所以...用 waitpid() 替换等待并用 sigaction() 禁用键盘中断(SIGINT 和 SIGQUIT),您将在后台执行。
我正在为大学做一个minishell项目,我不知道如何在后台执行命令。我知道的一件事是我必须使用 waitpid() 和 sigaction(),但我不知道如何使用。如果有人愿意帮助我,我将不胜感激。这是我使用的部分代码,用于使用 minishell 命令。
void execute_command_line(command* cmds, int n){
pid_t id,pid;
int status;
id=fork();
if(id==-1){
exit(EXIT_FAILURE);
}
else if(if==0){
execvp(cmds[0] . argv[0],&cmds[0] .argv[0]);
exit(0);
}
else{
pid=wait(&status);
if(pid==-1){
perror("Father: an error has ocurred.\n");
exit(EXIT_FAILURE);
}
else if(pid==id){
printf("Father: the son has ended.\n");
}
}
}
后台进程的一个关键特征是您无法与其交互(但它仍然可以打印到您的终端)。这至少意味着键盘生成的信号不得传递给该进程。 这可以通过调用 setsid() 创建一个新会话来完成,或者可以通过简单地禁用子进程中的键盘信号来模拟(有你的 sigaction)。
使用 waitpid 意味着您的父级可能不会立即退出,而是会等待(使用 waitpid)后台子级完成。
所以...用 waitpid() 替换等待并用 sigaction() 禁用键盘中断(SIGINT 和 SIGQUIT),您将在后台执行。