操作系统实验一 Linux基本环境及进程管理(10)
时间:2025-07-07
时间:2025-07-07
操作系统实验一 Linux基本环境及进程管理
( 2 )预置对信号的处理方式。接收信号的程序用 signal( ) 来实现对处理方式的预置; ( 3 )收受信号的进程按事先的规定完成对相应事件的处理。
2 、信号的发送
信号的发送,是指由发送进程把信号送到指定进程的信号域的某一位上。如果目标进程正在一个可被中断的优先级上睡眠,核心便将它唤醒,发送进程就此结束。一个进程可能在其信号域中有多个位被置位,代表有多种类型的信号到达,但对于一类信号,进程却只能记住其中的某一个。
进程用 kill( ) 向一个进程或一组进程发送一个信号。
3 、对信号的处理
当一个进程要进入或退出一个低优先级睡眠状态时,或一个进程即将从核心态返回用户态时,核心都要检查该进程是否已收到软中断。当进程处于核心态时,即使收到软中断也不予理睬;只有当它返回到用户态后,才处理软中断信号。对软中断信号的处理分三种情况进行: ( 1 )如果进程收到的软中断是一个已决定要忽略的信号( function=1 ),进程不做任何处理便立即返回;
( 2 )进程收到软中断后便退出( function=0 );
( 3 )执行用户设置的软中断处理程序。
二、所涉及的中断调用
1 、 kill( )
系统调用格式
int kill(pid,sig)
参数定义
int pid,sig;
其中, pid 是一个或一组进程的标识符,参数 sig 是要发送的软中断信号。
( 1 ) pid>0 时,核心将信号发送给进程 pid 。
( 2 ) pid=0 时,核心将信号发送给与发送进程同组的所有进程。
( 3 ) pid=-1 时,核心将信号发送给所有用户标识符真正等于发送进程的有效用户标识号的进程。
2 、 signal( )
预置对信号的处理方式,允许调用进程控制软中断信号。
系统调用格式
signal(sig,function)
头文件为
#include <signal.h>
参数定义
signal(sig,function)
int sig;
void (*func) ( )
其中 sig 用于指定信号的类型, sig 为 0 则表示没有收到任何信号,余者如下表:
操作系统实验一 Linux基本环境及进程管理
function :在该进程中的一个函数地址,在核心返回用户态时,它以软中断信号的序号作为参数调用该函数,对除了信号 SIGKILL , SIGTRAP 和 SIGPWR 以外的信号,核心自动地重新设置软中断信号处理程序的值为SIG_DFL ,一个进程不能捕获 SIGKILL 信号。 function 的解释如下:
( 1 ) function=1 时,进程对 sig 类信号不予理睬,亦即屏蔽了该类信号;
( 2 ) function=0 时,缺省值,进程在收到 sig 信号后应终止自己;
( 3 ) function 为非 0 ,非 1 类整数时, function 的值即作为信号处理程序的指针。
三、参考程序
#include <stdio.h>
#include<stdlib.h>
#include <signal.h>
#include <unistd.h>
void waiting( ),stop( );
int wait_mark;
main( )
{
int p1,p2,stdout;
while((p1=fork( ))= =-1); /* 创建子进程 p1*/
if (p1>0)
{
while((p2=fork( ))= =-1); /* 创建子进程 p2*/
if(p2>0)
{
wait_mark=1;
signal(SIGINT,stop); /* 接收到 ^c 信号,转 stop*/
waiting( );
操作系统实验一 Linux基本环境及进程管理
kill(p1,16); /* 向 p1 发软中断信号 16*/
kill(p2,17); /* 向 p2 发软中断信号 17*/
wait(0); /* 同步 */
wait(0);
printf("Parent process is killed!/n");
exit(0);
}
else
{
wait_mark=1;
signal(17,stop); /* 接收到软中断信号 17 ,转 stop*/
waiting( );
lockf(1,1,0);
printf("Child process 2 is killed by parent!/n");
lockf(1,0,0);
exit(0);
}
}
else
{
wait_mark=1;
signal(16,stop); /* 接收到软中断信号 16 ,转 stop*/
waiting( );
lockf(1,1,0);
printf("Child process 1 is killed by parent!/n");
lockf(1,0,0);
exit(0);
}
}
void waiting( )
{
while(wait_mark!=0);
}
void stop( )
{
wait_mark=0;
}
四、运行结果
屏幕上无反应,按下ctrl+c (接收到SIGINT信号)后,显示 Parent process is killed!
五、分析原因
上述程序中, signal( ) 都放在一段程序的前面部位,而不是在其他接收信号处。这是因为 signal( ) 的执行只是为进程指定信号值 16 或 17 的作用,以及分配相应的与 stop( ) 过程链接的指针。因而, signal( ) 函数必须在程序前面部分执行。
本方法通信效率低,当通信数据量较大时一般不用此法。
…… 此处隐藏:359字,全部文档内容请下载后查看。喜欢就下载吧 ……上一篇:外研版四年级英语上册M3测试题
下一篇:最新的计算机应用基础单选多选题