Linux c 屏蔽信号、切换信号
信号导致的问题
不是任何信号我们都需要的,如果遇到我们不想处理的信号,我们怎么避免这个信号?
1. 信号屏蔽
intsigprocmask(int how,//操作方式
SIG_BLOCK屏蔽信号
SIG_UNBLOCK剪除屏蔽信号
SIG_SETMASK修改屏蔽信号
constsigset_t *sigs,//操作的信号集合
sigset_t*oldsigs);//返回原来操作的信号集合
返回值:执行成功返回0,失败返回-1。
屏蔽信号的步骤:
1. 声明信号集
sigset_t sigs;
2. 加入屏蔽信号
一组信号集合维护函数
2.1. 清空集合sigemptyset
int sigemptyset( sigset_t *set);
2.2. 添加信号到集合sigaddset
int sigaddset( sigset_t *set ,int signum);
2.3. 从集合删除信号sigdelset
int sigdelset(sigset_t *set,int signum);
2.4. 添加所有信号到集合sigfillset
int sigfillset( sigset_t*set);
2.5. 判定信号是否在集合sigismember
int sigismember(const sigset_t *set ,int signum);
3. 屏蔽信号
4. 接触屏蔽
例子:
#include<stdio.h>
#include<signal.h>
void main()
{
int sum=0;
//声明信号集
sigset_t sigs;
//清空信号集
sigemptyset(&sigs);
//添加信号到信号集
sigaddset(&sigs,SIGINT); //
//屏蔽信号
sigprocmask( SIG_BLOCK,&sigs,0);
for(i=1;i<=10;i++)
{
sum+=i;
sleep(1);
}
printf(“sum=%d\n”,sum);
//捡出屏蔽
sigprocmask(SIG_UNBLOCK,&sigs,0);//捡出屏蔽,信号立即触犯,打印over不能//执行,如果没有捡出屏蔽信号,over正常打印
printf(“OVER!\n”);
}
说明:当屏蔽了某个信号,这个信号将不会触发,直到我们捡出了该信号,信号才会触发。
2.查询被屏蔽的信号
intsigpending(sigset_t *sets); 返回0成功,-1失败
例子:
#include<stdio.h>
#include<signal.h>
void main()
{
int sum=0;
//声明信号集
sigset_t sigs;
sigset_t sigp;
//清空信号集
sigemptyset(&sigs);
//添加信号到信号集
sigaddset(&sigs,SIGINT); //
//屏蔽信号
sigprocmask( SIG_BLOCK,&sigs,0);
for(i=1;i<=10;i++)
{
sum+=i;
sigpending(&sigp);//得到屏蔽的信号
if(sigismemeber(&sigp,SIGINT))
{
printf(“信号SIGINT在排队\n”);
}
sleep(1);
}
printf(“sum=%d\n”,sum);
//捡出屏蔽
sigprocmask(SIG_UNBLOCK,&sigs,0);
printf(“OVER!\n”);
}
2. 信号屏蔽的切换
int sigsuspend(sigset_t *sigs);
屏蔽新的信号,原来的信号失效.
sigsuspend是阻塞函数.对参数信号屏蔽.
对参数没有指定的信号不屏蔽,但当没有屏蔽信号处理函数调用完毕
sigsuspend返回条件:
1.信号发生,并且信号是非屏蔽信号
2.信号必须要处理,而且处理函数返回后,sigsuspend才返回.
sigsuspend设置新的屏蔽信号,保存旧的屏蔽信号
而且当sigsuspend返回的时候,恢复旧的屏蔽信号.
函数sigsuspend将进程的信号屏蔽码设置为sigs,然后与pause()函数一样等待信号的发生并执行完信号处理函数。信号处理函数执行完后再把进程的信号屏蔽码设置为原来的屏蔽字,然后sigsuspend函数才返回。 Sigsuspend总是返回-1。
例子:
#include<stdio.h>
#include<unistd.h>
#include<signal.h>
void deal()
{
printf(“处理信号SIGINT\n”);
}
void main()
{
signal(SIGINT,deal);
int sum=0;
//声明信号集
sigset_t sigs;
sigset_t sigp;
sigset_t newsig=NULL;
//清空信号集
sigemptyset(&sigs);
//添加信号到信号集
sigaddset(&sigs,SIGINT); //
//屏蔽信号
sigprocmask( SIG_BLOCK,&sigs,0);
for(i=1;i<=10;i++)
{
sum+=i;
sigpending(&sigp);//得到屏蔽的信号
if(sigismemeber(&sigp,SIGINT))
{
printf(“信号SIGINT在排队\n”);
sigsuspend(&newsig);//切换屏蔽信号,等待SIGINT信号,并调用处//理函数后函数返回。
}
sleep(1);
}
printf(“sum=%d\n”,sum);
}
说明:程序检查到屏蔽信号中有SIGINT信号在排队,就调用sigsuspend函数切换屏蔽信号,程序处理SIGINT信号后,sigsuspend函数才返回。
Linux c 屏蔽信号、切换信号的更多相关文章
- Linux信号-信号集&信号屏蔽字&捕捉信号【转】
转自:https://blog.csdn.net/Lycorisradiata__/article/details/80096203 一. 阻塞信号 1. 信号的常见其他概念 实际执行信号的处理 ...
- 三十四、Linux 进程与信号——信号特点、信号集和信号屏蔽函数
34.1 信号特点 信号的发生是随机的,但信号在何种条件下发生是可预测的 进程杠开始启动时,所有信号的处理方式要么默认,要么忽略:忽略是 SIGUSR1 和 SIGUSR2 两个信号,其他都采取默认方 ...
- 信号屏蔽的切换的理解sigsuspend
#include <stdio.h> #include <stdlib.h> #include <signal.h> #include <unistd.h&g ...
- Linux C 程序 信号及信号的处理(19)
信号及信号的处理 1.Linux信号的介绍 信号是一种软件中断.Linux系统中根据POSIX标准扩展的信号机制. 1.信号来源 1.硬件方式 1.当用户按下某个键, ...
- Linux系统编程之----》信号
"===信号========================================================================================= ...
- Linux系统编程——进程间通信:信号中断处理
什么是信号? 信号是 Linux 进程间通信的最古老的方式.信号是url=474nN303T2Oe2ehYZjkrggeXCaJPDSrmM5Unoh4TTuty4wSgS0nl4-vl43AGMFb ...
- Linux下shell脚本中信号捕获和函数练习脚本之ping一个网段
该脚本主要的目的是练习在Linux bash脚本中捕获信号,顺便练习一下函数的使用,还有就是终止一个正在运行的程序后,该程序打开的文件的后续处理问题等等!脚本功能: ping一个网段内的IP,检测哪 ...
- [Linux]返回被阻塞的信号集
一.概述 在另一篇实例说到,进程可以屏蔽它不想接收的信号集. 事实上这些被屏蔽的信号只是阻塞在内核的进程表中,因为他们不能递送给进程,所以状态是未决的(pending). 利用sigpending函数 ...
- linux 进程学习笔记-进程信号sigal
信号(或软中断)是在软件层次上对中断的一个模拟,其运行在“用户空间”,一个进程对另外一个或几个进程通过发送信号来实现异步通信.当接收进程接收到信号后,其可以注册一下处理函数来说对这些信号进行处理(也可 ...
随机推荐
- keystone 认证深度研究分析
一.Keystone Token深度概述 Keystone作为OpenStack项目基础认证模块,目前支持的token类型分别是uuid.pkiz.pki.fernet. 首先,简要叙述一下这四种类型 ...
- 洛谷.4525.[模板]自适应辛普森法1(Simpson积分)
题目链接 Simpson积分公式:\[\int_a^bf(x)dx\approx\frac{b-a}{6}\left[f(a)+f(b)+4f(\frac{a+b}{2})\right]\] 推导过程 ...
- 【扩展欧几里得】BZOJ1477-青蛙的约会
一直在WA,后来我发现我把东西看反了…… [题目大意] 给出一个长度为L的环状坐标轴,两个点开始时位于(X,0).(Y,0).每次两点分别往右边移动m和n,问能否相遇? [思路] 由题意,可得: X+ ...
- hdu 1698 线段树 成段更新
题意:一段钩子,每个钩子的值为1,有若干更新,每次跟新某段的值,若干查询某段的和 基础题了 #include<cstdio> #include<iostream> #inclu ...
- poj 3264 线段树
题目意思:给定Q(1<=Q<=200000)个数A1,A2,```,AQ, 多次求任一区间Ai-Aj中最大数和最小数的差 线段树太弱了,题目逼格一高连代码都读不懂,今天开始重刷线段树,每天 ...
- java的多线程之四(线程的操作)
本文来自:高爽|Coder,原文地址:http://blog.csdn.net/ghsau/article/details/17560467,转载请注明. 线程中断 线程中断涉及到三个方法,如下 ...
- C++反汇编-结构体和类
学无止尽,积土成山,积水成渊-<C++反汇编与逆向分析技术揭秘> 读书笔记 对象的内存布局 一般计算公式: 对象内存大小 = sizeof(数据成员1)+ sizeof(数据成员2) +. ...
- ARM JTAG 20
http://infocenter.arm.com/help/index.jsp?topic=/com.arm.doc.dui0499b/BEHEIHCE.html he ARM JTAG 20 co ...
- linux下面mmap和setsignal函数用法
#include <stdio.h> #include <stdlib.h> #include <sys/mman.h> #include <fcntl.h& ...
- MVC扩展生成CheckBoxList并水平排列
本篇体验生成CheckBoxList的几个思路,扩展MVC的HtmlHelper生成CheckBoxList,并使之水平排开. 通过遍历从控制器方法拿到的Model集合 □ 思路 比如为一个用 ...