linux下变成——操作系统——信号

Posted 可爱小夫

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了linux下变成——操作系统——信号相关的知识,希望对你有一定的参考价值。

相关知识:

1kill( )

系统调用格式

int  kill(pid,sig)

参数定义

int  pid,sig;

其中,pid是一个或一组进程的标识符,参数sig是要发送的软中断信号。

1pid>0时,核心将信号发送给进程pid

2pid=0时,核心将信号发送给与发送进程同组的所有进程。

3pid=-1时,核心将信号发送给所有用户标识符真正等于发送进程的有效用户标识号的进程。

2signal( )

预置对信号的处理方式,允许调用进程控制软中断信号。

系统调用格式

signal(sig,function)

头文件为

                   #include <signal.h>

参数定义

signal(sig,function)

int  sig;

void (*func) ( )

其中sig用于指定信号的类型,sig0则表示没有收到任何信号。

 

 

 

名  字

说          明

01

SIGHUP

挂起(hangup

02

SIGINT

中断,当用户从键盘按^c键或^break键时

03

SIGQUIT

退出,当用户从键盘按quit键时

04

SIGILL

非法指令

05

SIGTRAP

跟踪陷阱(trace trap),启动进程,跟踪代码的执行

06

SIGIOT

IOT指令

07

SIGEMT

EMT指令

08

SIGFPE

浮点运算溢出

09

SIGKILL

杀死、终止进程

10

SIGBUS

总线错误

11

SIGSEGV

段违例(segmentation  violation),进程试图去访问其虚地址空间以外的位置

12

SIGSYS

系统调用中参数错,如系统调用号非法

13

SIGPIPE

向某个非读管道中写入数据

14

SIGALRM

闹钟。当某进程希望在某时间后接收信号时发此信号

15

SIGTERM

软件终止(software  termination

16

SIGUSR1

用户自定义信号1

17

SIGUSR2

用户自定义信号2

18

SIGCLD

某个子进程死

19

SIGPWR

电源故障

 

function:在该进程中的一个函数地址,在核心返回用户态时,它以软中断信号的序号作为参数调用该函数,对除了信号SIGKILLSIGTRAPSIGPWR以外的信号,核心自动地重新设置软中断信号处理程序的值为SIG_DFL,一个进程不能捕获SIGKILL信号。

function 的解释如下:

1function=1时,进程对sig类信号不予理睬,亦即屏蔽了该类信号;

2function=0时,缺省值,进程在收到sig信号后应终止自己;

3function为非0,非1类整数时,function的值即作为信号处理程序的指针。

 

signal.h中的宏定义SIG_DFLSIG_IGN

SIG_DFL,SIG_IGN 分别表示无返回值的函数指针,指针值分别是01,这两个指针值逻辑上讲是实际程序中不可能出现的函数地址值。
SIG_DFL:默认信号处理程序
SIG_IGN:忽略信号的处理程序

 

题目描述:

按下^C后,显示

 

 

Child process 1 is killed by parent!

Child process 2 is killed by parent!

 Parent  process  is  killed!

程序源码:

#include <stdio.h>
#include <signal.h>
#include <unistd.h>
#include <stdlib.h>

void waiting(),stop();
int wait_mark;
main()
{
    int p1,p2,stdout;
    sigset_t sigs;//声明信号集
    sigemptyset(&sigs);//初始化信号集
    sigaddset(&sigs,SIGINT);//向信号集中添加信号
    
    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();
            kill(p1,10);        /*向p1发软中断信号16*/
            kill(p2,12);        /*向p2发软中断信号17*/
            wait(0);           /*同步*/
            wait(0);
            printf("Parent process is killed!
");
            exit(0);
        }
        else
        {
            sigprocmask(SIG_BLOCK,&sigs,NULL);//SIG_BLOCK为屏蔽信号集,0为成功,-1为失败
                wait_mark=1;
            signal(12,stop);   /*接收到软中断信号17,转stop*/
            waiting();
            lockf(stdout,1,0);
            printf("Child process 2 is killed by parent!
");
            lockf(stdout,0,0);
            exit(0);
        }
    }
    else
    {
        sigprocmask(SIG_BLOCK,&sigs,NULL);//SIG_BLOCK为屏蔽信号集,0为成功,-1为失败
        wait_mark=1;
        signal(10,stop);        /*接收到软中断信号16,转stop*/
        waiting();
        lockf(stdout,1,0);
        printf("Child process 1 is killed by parent!
");
        lockf(stdout,0,0);
        exit(0);
    }
}

void waiting()
{
     while(wait_mark!=0);
}

void stop()
{
    wait_mark=0;
}

 

 

 

以上是关于linux下变成——操作系统——信号的主要内容,如果未能解决你的问题,请参考以下文章

Linux下信号

linux打开终端如何启动scala,如何在终端下运行Scala代码片段?

如何在Linux下实现定时器

MacBook Pro/Air 下使用 linux ubuntu 系统 波浪号“~”变成其他 符号 的完美解决办法

一文搞懂 , Linux内核—— 同步管理(下)

Linux下实现定时器Timer的几种方法