我目前正在编写一个简单的shell在C中,我面临的信号问题。处理信号sigtstp - sigcont - sigint与子进程在C
例如,当我启动我的程序时,我键入ping命令,然后键入CTRL-Z我希望子进程(ping命令)暂停,然后在我使用fg时回来。
我认为我需要存储一个全局变量执行ping命令的子pid。
我已经检查了其他帖子来解决我自己的问题,但我无法得到它的工作。
这是执行命令(多个命令| |)和存储子pid的代码。
int exec_proc(int input, int output, char** command) {
pid_t runner;
runner = fork();
f_pid = runner;
if (runner == 0) {
// Use input for stdin
if (input != 0) {
dup2(input, 0);
close(input);
}
// Use output for stdout
if (output != 1) {
dup2(output, 1);
close(output);
}
// Return command code
execvp(command[0], command);
}
// An error occured
return -1;
这是我的处理程序c文件。
pid_t f_pid;
/**
* Handles every handler !
*/
void handlerManager()
{
signal(SIGINT,INTHandler);
signal(SIGTSTP,TSTPHandler);
signal(SIGCONT,CONTHandler);
}
/**
* Handler for CTRL-C
* @param sig
*/
void INTHandler(int sig)
{
printf("\nDo you really want to quit ? [y/n] \n");
int answer = getchar();
if(toupper(answer) == 'Y')
kill(f_pid,SIGINT);
}
/**
* Handler for CTRL-Z (processus sleep)
* @param sig
*/
void TSTPHandler(int sig)
{
printf("\nGoing to sleep! \n");
printf("%d", f_pid);
kill(f_pid,SIGTSTP);
}
/**
* Handler to reset a processus
* @param sig
*/
void CONTHandler(int sig)
{
printf("\nHey i'm awake\n");
kill(f_pid,SIGCONT);
}`
当我打印PID时,我得到正确的PID。
最后这个地方我打电话给我的处理程序管理器。
int main() {
char* line;
char** args[MAX_ARG_SIZE] = {NULL};
int status;
handlerManager();
do {
fflush(stdin);
prompt();
line = readline();
char linecpy[strlen(line)];
strcpy(linecpy, line);
splitBy(line, " ", args);
status = exec(args, linecpy);
switch (status) {
case EMPTY_LINE:
break;
}
} while (status);
return 0;
在此先谢谢您,并对我的英语感到抱歉。
嗨,谢谢你的回答我做了更改,但是当我在命令中按Ctrl-Z时,它确实改变了processus的状态,但是当我键入fg时,我在子进程(ping命令) 。 –
请参阅编辑。 –