要求:
1)售票员捕捉SIGINT(代表开车)信号,向司机发送SIGUSR1信号,司机打印(let's gogogo)
2)售票员捕捉SIGQUIT(代表停车)信号,向司机发送SIGUSR2信号,司机打印(stop the bus)
3)司机捕捉SIGTSTP(代表到达终点站)信号,向售票员发送SIGUSR1信号,售票员打印(please get off the bus)
4)司机等待售票员下车,之后司机再下车。
分析:司机(父进程)、售票员(子进程)
售票: 捕捉:SIGINT SIGQUIT SIGUSR1
忽略:SIGTSTP
司机: 捕捉:SIGUSR1 SIGUSR2 SIGTSTP
忽略:SIGINT SIGQUIT
// 售票员只需要捕捉代表开车 停车的信号,并向司机发送信号;最后捕捉到战后司机发出的下车信号
// 司机只需要捕捉售票员发出的信号与到站信号,向售票员发出下车信号
#include <stdio.h>
#include <signal.h>
#include <stdlib.h>
#include <unistd.h>
#include <semaphore.h>
#include <pthread.h>
#include <sys/types.h>
#include <sys/wait.h>
// 售票员只需要捕捉代表开车 停车的信号,并向司机发送信号;最后捕捉到战后司机发出的下车信号
// 司机只需要捕捉售票员发出的信号与到站信号,向售票员发出下车信号
pid_t pid;
void saler(int sig)
{
if (sig == SIGINT)
{
kill(getppid(), SIGUSR1); //向父发送sigusr1 开车
}
else if (sig == SIGQUIT)
{
kill(getppid(), SIGUSR2); //向父发送sigusr2 停车
}
else if (sig == SIGUSR1) //当父发送过来sigusr1 售票员下车
{
printf("please get off the bus");
exit(0);
}
}
void driver(int sig)
{
if (sig == SIGUSR1) //接受子发送的sigusr1 发车
{
printf("let gogogo!\n");
}
else if (sig == SIGUSR2) //接受子发送的sigusr2 停车
{
printf("stop bus!\n");
}
else if (sig == SIGTSTP) // 接受到到站信号 //向子发送sigusr2 ,售票员下车
{
kill(pid, SIGUSR1);
// sleep(1);
wait(NULL);
exit(0);
}
}
int main(int argc, char const *argv[])
{
pid = fork();
if (pid < 0)
{
perror("forke rr");
return -1;
}
else if (pid == 0)
{
printf("saler\n");
signal(SIGTSTP, SIG_IGN); //子忽略SIGTSTP // 忽略发给司机的到站信号
signal(SIGINT, saler); //捕捉SIGINT // 捕捉开车信号
signal(SIGQUIT, saler); //捕捉SIGQUIT // 捕捉停车信号
signal(SIGUSR1, saler); //捕捉SIGUSR1 // 捕捉司机发出到站之后发送的下车信号
}
else
{
printf("driver\n");
signal(SIGINT, SIG_IGN); //父忽略SIGINT // 忽略发给售票员的开车信号
signal(SIGQUIT, SIG_IGN); //父忽略SIGQUIT // 忽略发给售票员的停车信号
signal(SIGUSR1, driver); //父捕捉SIGUSR1 // 捕捉售票员发出的开车信号
signal(SIGUSR2, driver); //父捕捉SIGUSR2 // 捕捉售票员发出的停车信号
signal(SIGTSTP, driver); //父捕捉SIGTSTP // 捕捉到站信号
}
while (1)
pause(); //不能只发送一个信号就结束
return 0;
}