文章目录
- 一、实验目的
- 二、实验内容
- 三、实验要求
- 四、实验步骤及操作
- 五、程序源码
- 1. 信号发送 fkill.c
- 2. 信号监控 mysignal.c
一、实验目的
1.了解进程通信间的信号机制
2.掌握进程通信间的信号编程模型
二、实验内容
信号是通信量最小的一种进程间通信形式,也用于内核与进程间的通信,信号是软件中断,它传递异步信号。本次实验内容如下:
1.使用kill函数杀死另一进程
2.信号的处理
3.阻塞信号
4.检测挂起的信号,设置信号处理程序
三、实验要求
实验需提前准备一台PC机,并在PC机上搭建Linux Ubuntu环境。
四、实验步骤及操作
1.打开Linux系统,新建终端
2.新建文件
3.编写代码
4.编译运行
五、程序源码
1. 信号发送 fkill.c
#include <sys/types.h>
#include <wait.h>
#include <unistd.h>
#include <signal.h>
#include <stdio.h>
#include <stdlib.h>
int main(void)
{
pid_t child;
int errret;
if((child = fork()) < 0) {
perror("fork");
exit(EXIT_FAILURE);
} else if(child == 0) { /* in the child process */
sleep(30);//使当前进程睡眠30s
} else { /* in the parent */
/* 发送一个被忽略的信号 */
printf("sending SIGCHLD to %d\n", child);//SIGCHLD标识子进程停止或结束的信号
errret = kill(child, SIGCHLD); //向child进程号发送SIGCHLD信号
if(errret < 0)
perror("kill:SIGCHLD");
else
printf("%d still alive\n", child);
/* now murder the child */
printf("killing %d\n", child);
if((kill(child, SIGTERM)) < 0)//SIGTERM是kill发送的软件结束信号
perror("kill:SIGTERM");
/* have to wait to reap the status */
waitpid(child, NULL, 0 ); //回收子进程
}
exit(EXIT_SUCCESS);
}
2. 信号监控 mysignal.c
#include <signal.h>
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
void my_func(int sign_no)
{
if(sign_no==SIGINT) //程序终止(interrupt)信号, 在用户键入INTR字符(通常是Ctrl-C)时发出,用于通知前台进程组终止进程
printf("I have get SIGINT\n");
else if(sign_no==SIGQUIT)
printf("I have get SIGQUIT\n"); //SIGQUIT 信号对应的 signo = 03,表示用户从键盘按下quit键,即 ctrl+\ ,
//进程在收到 SIGQUIT 退出时会产生 core 文件,在这个意义上类似于一个程序错误信号。
}
int main()
{
printf("Waiting for signal SIGINT or SIGQUIT \n ");
signal(SIGINT, my_func); //参数一:处理信号 参数二:处理方式
signal(SIGQUIT, my_func);
pause(); //令目前的进程暂停(进入睡眠状态), 直到被信号(signal)所中断
exit(0);
}