信号的基本概念以及信号的产生

一. 信号产生的场景

     1. 用户输入命令, 在shell 启动一个前台进程
     2. 当用户按一下 Ctrl + C 的时候,从键盘产生一个硬件中断
     3. 此时CPU 正在执行这个进程的带代码, 则该进程的执行代码暂停执行, CPU 从用户态切换到内核态处理该硬件中断.
     4. 中断驱动程序将Ctrl + C 解释为一个 SIGIN 信号, 记在该进程的 PCB 中(操作系统给进程法送了一个 SUGIN 信号)
     5. 当操作系统要从内核返回到该进程的代码继续执行之前, 首先要处理PCB中记录的信号, 发现了一个 SUGIN 信号, 而该信号的默认处理动作是终止进程, 所以此时进程直接终止, 不再返回.

注意:

    1. Ctr + C 只能发给一个前台正在运行的进程, 一个命令后加 & 便可以将该进程放在后台取执行, 这样shell就不用等待进程结束便可以启动新的进程
    2. shell 可以一次执行一个前台进程, 但可以一次执行多个后台进程, 只有前台信号才能接受控制键产生的信号
    3. 进程在运行的如何时候都可以接到像 Ctr + C 的这种键盘控制信号而终止, 因此信号相对于进程而言是异步的.

查看信号的命令: kill -l这里写图片描述

    其中前 31 个信号属于普通信号, 没有 32 和 33 号信号, Ctrl + C 产生 11 号 SIGSEGV 信号, Ctrl + Z 产生 SIGTSTP 20 号信号, Ctrl + / 产生 SIGQUIT 3 号信号.

二. 信号产生的几种方式

    1. 用户在终端键盘产生中断,终端驱动程序会发送信号给当前前台进程,.
    2. 硬件异常产生中断,如执行除以 0 的操作, 此时 CPU 运算单元产生异常, 内核将这个异常解释为一个 SUGFPE 发送给该前台进程, 或者当程序访问了非法内存时, 此时MMU产生一个异常, 内核将这个异常解释为 SIGSEGV 发送给该进程.
    3. 通过命令给当前进程发送信号 kill -11 test(给test进程发送 11 号信号)
    4. 软件条件产生异常, 如管道读写时, 读端关闭, 此时写端还在继续写, 此时,操作系统会给当前进程发送一个 13 号信号, 进程发现这个信号, 退出.

三. 调用系统函数给信号发送信号

    1.kill -信号编号 进程编号
    2.kill -信号名 进程编号
                这里写图片描述
    该进程是一个死循环的程序, 但此时给该进程发送一个11号信号, 这个信号在进程眼里就是一个SIGEGV 信号, 进程收到这个信号的默认执行动作是终止信号, 并且给用户发送段错误提示信息.
    3. kill 命令的函数实现
                                这里写图片描述
    其中 pid 指的是该进程的 pid, sig 指的是需要发送的信号的编号.
    kill 函数用来给对应进程发送一个编号为 sig 的信号
    raise 函数用来给当前进程发送一个编号为 signo 的信号
    abort 函数是是当前信号接收到信号而异常终止

四. 软件条件产生信号

                             这里写图片描述
    用来设定一个闹钟, 告诉内核在 seconds 秒之后给进程发送一个SIGALRM 信号, 该信号的默认执行动作时终止当前进程. 函数的返回值是 0 或者是以前设定的闹钟时间还余下的秒数.如果将 seconds 设为 0, 表示取消以前设定的闹钟,闹钟的返回值任然是以前设定的闹钟剩余的秒数.

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/384073.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

HDU - 1028——母函数入门

【题目描述】 “Well, it seems the first problem is too easy. I will let you know how foolish you are later.” feng5166 says. “The second problem is, given an positive integer N, we define an equation like this: Na[1]a[2]a[3]…a[m]; a[i]>0,1<m<N;…

信号的阻塞

一. 阻塞信号 1.信号的相关概念     (1) 递达: 实际执行信号的处理动作称为信号的递达     (2) 未决: 信号从产生到递达之间的过程叫做信号的未决     (3) 阻塞: 进程可以选择阻塞某个信号, 被阻塞的信号产生时将保持在未决状态, 直到进程解除该信号的屏蔽, 才…

POJ 1511 Invitation Cards——Dijkstra优先队列优化+反向建图

【题目描述】 In the age of television, not many people attend theater performances. Antique Comedians of Malidinesia are aware of this fact. They want to propagate theater and, most of all, Antique Comedies. They have printed invitation cards with all the…

链栈 尹成

http://blog.csdn.net/itcastcpp/article/details/39271661 今天&#xff0c;我们一起用C写链栈&#xff0c;具体如下。 LinkStack.h具体内容&#xff1a; [cpp] view plaincopy #include "StackNode.h" template<typename Type> class LinkStack{ publ…

信号的捕捉以及SIGCHLD信号

一. 信号的捕捉定义 用户提供一个处理函数, 要求内核在处理信号时必须切换到用户态,执行这个函数, 这种方式就叫做信号的捕捉 二. 图解信号的捕捉过程 1. 由上图可以看出,当处理信号的执行动作时用户自定义的时候,此时就需返回该函数去调用该函数, 这就叫做信号的捕捉. 以前我…

链队 尹成

http://blog.csdn.net/itcastcpp/article/details/39271691 今天&#xff0c;我们一起用C写一个链对&#xff0c;具体如下所示。 LinkQueue.h具体内容如下&#xff1a; [cpp] view plaincopy #include "QueueNode.h" template<typename Type> class LinkQueu…

强连通分量入门——Trajan算法

今天学习了强连通分量。 【参考博客】 如果觉得我讲的有些地方难以理解或者存在问题&#xff08;欢迎留言&#xff09;&#xff0c;可以看一下我借鉴的一些大佬的博客&#xff1a; 传送门1 传送门2 【知识储备】 首先我们需要对几个定义有一些概念&#xff1a; 强连通&#xff…

最小栈的实现

所谓最小栈, 就是当前栈顶元素最小, 我们可以这样做, 每次在入栈之前, 将待入栈元素与栈顶元素相比, 每次现将待入栈的元素先入栈, 再将带入栈的元素和较小的元素入栈, 这样就可以保证每次栈顶元素是最小元素. 在出栈的时候规定每次出栈两个元素,这样就可以保证在出栈之后栈顶元…

用C++实现单链表的创建、逆置和输出 的两种方法

http://blog.csdn.net/lfeng_coding/article/details/47300563 题目描述&#xff1a;在已知单链表头节点的情况下&#xff0c;设计算法逆置单链表并输出 方法一&#xff1a;采用首先将头节点指向空&#xff0c;让其变为尾节点&#xff0c;然后利用中间节点 p、q 将其后的节点一…

两个栈实现一个队列

利用两个栈实现一个队列思路是这样的. 首先这个队列包含两个栈, 然后一个栈用来入队列, 一个栈用来出队列 typedef struct QueBy2Stack {SeqStack input;SeqStack output; }QueBy2Stack; 1. 初始化 void QueBy2StackInit(QueBy2Stack* stack) {if(stack NULL){return;//非法…

HDU 5934:Boom——强连通分量+缩点

【题目描述】 There are N bombs needing exploding.Each bomb has three attributes: exploding radius ri, position (xi,yi) and lighting-cost ci which means you need to pay ci cost making it explode.If a un-lighting bomb is in or on the border the exploding ar…

Linux--线程死锁

http://blog.csdn.net/gebushuaidanhenhuai/article/details/73799824 线程为什会死锁&#xff1f;&#xff1f;“锁”又是什么东西&#xff1f;我们这篇博客主要讲一下为什么要给线程加锁&#xff0c;为什么会出现线程死锁&#xff0c;线程死锁怎么解决。 互斥锁 在我的上篇博…

两个队列实现一个栈

用两个队列实现一个栈的原理是这样的. 规定两个队列, 必须有一个队列是非空, 一个队列是空.每次入栈时必须往非空队列中入, 而每次出栈时, 必须将非空队列里的元素装到空队列中, 直到非空队列中只有一个元素时, 此时就将剩下的这个元素出栈即可. 而取栈顶元素时, 和出栈一样, 先…

POJ-1144 Network——Trajan+割点

【题目描述】 A Telephone Line Company (TLC) is establishing a new telephone cable network. They are connecting several places numbered by integers from 1 to N . No two places have the same number. The lines are bidirectional and always connect together tw…

Linux--生产者与消费者

http://blog.csdn.net/gebushuaidanhenhuai/article/details/74011636 基本概念 提到生产者和消费者&#xff0c;我们最有可能想到的是商店卖东西&#xff0c;顾客在货架上(缓冲区&#xff09;买东西。 生产者消费者问题&#xff0c;其实是一个多线程同步问题的经典案例。该问…

进程的挂起以及可重入函数

相关接口     pause 函数用于将进程挂起. 如果信号的处理动作是终止进程, 则进程终止, pause 函数没有返回值; 如果信号的处理动作是忽略, 则进程被挂起, pause函数不返回, 如果信号的处理动作是捕捉, 则调用信号处理动作之后pause 返回 -1.来看一段代码 #include<s…

POJ1236Network of Schools——强连通分量缩点建图

【题目描述】 A number of schools are connected to a computer network. Agreements have been developed among those schools: each school maintains a list of schools to which it distributes software (the “receiving schools”). Note that if B is in the distri…

C——通过调用函数分配内存

http://blog.csdn.net/u012627502/article/details/3579724 1&#xff09;以返回值方式返回&#xff1a;把动态分配的存储位置地址&#xff0c;赋值给指针类型返回值&#xff08;不同于被调用函数的自动变量地址&#xff09; 2&#xff09;以形参形式返回&#xff1a;二级指针类…

gdb调试多进程程序

1.gdb下调试多进程程序只需要以下几条命令即可              除此之外还可以查看正在调试的进程 info inferiors, 同时也可以将当前正在调试的进程切换到另外一个进程中让其取运行     2.代码调试演示 #include<stdio.h> #include<stdlib.h> #…

BZOJ1123-BLO——强连通分量求割点+计数

【题目描述】 Byteotia城市有n个 towns m条双向roads. 每条 road 连接 两个不同的 towns ,没有重复的road. 所有towns连通。Input 输入n<100000 m<500000及m条边Output 输出n个数&#xff0c;代表如果把第i个点去掉&#xff0c;将有多少对点不能互通。Sample Input 5…