Linux信号集 —— Signal set and using

2024-06-06 00:58
文章标签 linux signal set using 信号

本文主要是介绍Linux信号集 —— Signal set and using,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

  1.    信号集概念

  信号集是一个能表示多个信号的数据类型,sigset_t set ;set即一个信号集。

  既然是一个集合,就需要对集合进行添加/删除等操作。

  int sigemptyset(sigset_t *set); 将set集合置空

  int sigfillset(sigset_t *set); 将所有信号加入set集合

  int sigaddset(sigset_t *set,int signo); 将signo信号加入到set集合

  int sigdelset(sigset_t *set,int signo); 从set集合中移除signo信号

  int sigismember(const sigset_t *set,int signo); signo判断信号是否存在于set集合中

  代码举例:

  include<stdio.h>

  #include<stdlib.h>

  #include<sys/types.h>

  #include<sys/stat.h>

  #include<signal.h>

  int main()

  {

  sigset_t sigset;

  sigfillset(&sigset);/*填充所有信号*/

  if(sigismember(&sigset,SIGINT))/*判断SIGINT*/

  printf("SIGINT exist in signal_set!\n");

  if(sigismember(&sigset,SIGTERM))

  printf("SIGTERM exist in signal_set!\n");

  if(sigismember(&sigset,SIGABRT))

  printf("SIGABRT exist in signal_set!\n");

  if(sigdelset(&sigset,SIGINT)<0)/*移除SIGINT*/

  perror("del error\n");

  else

  printf("SIGINT have been removed!\n");

  if(sigismember(&sigset,SIGINT))/*再次判断*/

  printf("SIGINT exist in signal_set!\n");

  else

  printf("SIGINT not exist in signal_set!\n");

  }

  输出:

  $ ./sigset

  SIGINT exist in signal_set!

  SIGTERM exist in signal_set!

  SIGABRT exist in signal_set!

  SIGINT have been removed!

  SIGINT not exist in signal_set!

  2.    信号集的使用

  定义信号集->设置信号屏蔽位->定义信号处理函数->检测信号

  <1>使用1中的函数即可完成信号集的定义,之后是

  <2>设置信号屏蔽位

  其作用为设置某个进程需要屏蔽的信号

  Int sigprocmask(int how,const sigset_t *set,sigset_t *oset);

  参数

  How 指示如何修改屏蔽信号

  Set是一个非空指针时,根据how修改屏蔽信号

  Oset是一个非空指针时,存放当前屏蔽信号集

  若set为NULL,不改变该进程的信号屏蔽字,how也无意义

  How的取值:

  S I G B L O C K

  该进程新的信号屏蔽字是其当前信号屏蔽字和s e t指向信号集的并集。s e t包含了我们希望阻塞的附加信号

  S I G U N B L O C K

  该进程新的信号屏蔽字是其当前信号屏蔽字和s e t所指向信号集的交集。s e t包含了我们希望解除阻塞的信号

  S I G S E T M A S K

  该进程新的信号屏蔽是s e t指向的值

[NextPage]

  举例

  #include<stdio.h>

  #include<stdlib.h>

  #include<sys/types.h>

  #include<sys/stat.h>

  #include<signal.h>

  /*sigprocmsk的使用*/

  void msg(int signo)

  {

  if(signo==SIGINT)

  printf("Get SIGINT!\n");

  else

  printf("Get SIGQUIT!\n");

  }

  int main()

  {

  sigset_t sigset,oset;/*sigset存放屏蔽信号,oset保存当前屏蔽信号*/

  sigemptyset(&sigset);/*清空信号集*/

  sigaddset(&sigset,SIGINT);/*添加SIGINT信号,信号集中仅有SIGINT*/

  sigprocmask(SIG_BLOCK,&sigset,&oset);/*加入屏蔽信号*/

  signal(SIGINT,msg);

  signal(SIGQUIT,msg);

  sleep(2);

  raise(SIGINT);/*发送SIGINT信号*/

  raise(SIGQUIT); 30.}

  输出

  Get SIGQUIT!

  <3>定义信号处理函数

  s i g a c t i o n函数的功能是检查或修改(或两者)与指定信号相关联的处理动作。此函数取代了U N I X早期版本使用的s i g n a l函数

  Int sigaction(int signo,const struct sigaction *act,struct sigaction *oact);

  参数:signo 要检测或修改动作的信号量

  Act 非空时,表示要修改的动作

  Oact非空时,返回处理该信号的原先动作

  结构体sigaction如下:

  struct sigaction {

  void (*sa_handler)();/*处理函数或SIG_IGN(忽略)或SIG_DFL(默认)*/

  sigset_t sa_mask; /*处理函数过程中被阻塞*/

  int sa_flags; /*标志位,对信号进程处理选项*/

  } ;

  举例

  #include<stdio.h>

  #include<stdlib.h>

  #include<sys/types.h>

  #include<sys/stat.h>

  #include<signal.h>

  void msg(int signo)

  {

  if(signo==SIGINT)

  printf("Get SIGINT!\n");

  }

  int main()
 {

  sigset_t sigset,oset;/*sigset存放屏蔽信号,oset保存当前屏蔽信号*/

  struct sigaction action1,action2;/*信号处理*/

  action1.sa_handler=msg;

  sigaction(SIGINT,&action1,&action2);

  sleep(2);

  raise(SIGINT);/*发送SIGINT信号*/

  }

  输出:

  Get SIGINT

  <4>检测被搁置信号

  Int sigpending(sigset_t *set);

  返回对于调用进程被阻塞不能递送和当前未决的信号集。该信号集通过s e t参数返回。

 

这篇关于Linux信号集 —— Signal set and using的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1034672

相关文章

linux生产者,消费者问题

pthread_cond_wait() :用于阻塞当前线程,等待别的线程使用pthread_cond_signal()或pthread_cond_broadcast来唤醒它。 pthread_cond_wait() 必须与pthread_mutex 配套使用。pthread_cond_wait()函数一进入wait状态就会自动release mutex。当其他线程通过pthread

Linux 安装、配置Tomcat 的HTTPS

Linux 安装 、配置Tomcat的HTTPS 安装Tomcat 这里选择的是 tomcat 10.X ,需要Java 11及更高版本 Binary Distributions ->Core->选择 tar.gz包 下载、上传到内网服务器 /opt 目录tar -xzf 解压将解压的根目录改名为 tomat-10 并移动到 /opt 下, 形成个人习惯的路径 /opt/tomcat-10

RedHat运维-Linux文本操作基础-AWK进阶

你不用整理,跟着敲一遍,有个印象,然后把它保存到本地,以后要用再去看,如果有了新东西,你自个再添加。这是我参考牛客上的shell编程专项题,只不过换成了问答的方式而已。不用背,就算是我自己亲自敲,我现在好多也记不住。 1. 输出nowcoder.txt文件第5行的内容 2. 输出nowcoder.txt文件第6行的内容 3. 输出nowcoder.txt文件第7行的内容 4. 输出nowcode

【Linux进阶】UNIX体系结构分解——操作系统,内核,shell

1.什么是操作系统? 从严格意义上说,可将操作系统定义为一种软件,它控制计算机硬件资源,提供程序运行环境。我们通常将这种软件称为内核(kerel),因为它相对较小,而且位于环境的核心。  从广义上说,操作系统包括了内核和一些其他软件,这些软件使得计算机能够发挥作用,并使计算机具有自己的特生。这里所说的其他软件包括系统实用程序(system utility)、应用程序、shell以及公用函数库等

【操作系统】信号Signal超详解|捕捉函数

🔥博客主页: 我要成为C++领域大神🎥系列专栏:【C++核心编程】 【计算机网络】 【Linux编程】 【操作系统】 ❤️感谢大家点赞👍收藏⭐评论✍️ 本博客致力于知识分享,与更多的人进行学习交流 ​ 如何触发信号 信号是Linux下的经典技术,一般操作系统利用信号杀死违规进程,典型进程干预手段,信号除了杀死进程外也可以挂起进程 kill -l 查看系统支持的信号

Windows/macOS/Linux 安装 Redis 和 Redis Desktop Manager 可视化工具

本文所有安装都在macOS High Sierra 10.13.4进行,Windows安装相对容易些,Linux安装与macOS类似,文中会做区分讲解 1. Redis安装 1.下载Redis https://redis.io/download 把下载的源码更名为redis-4.0.9-source,我喜欢跟maven、Tomcat放在一起,就放到/Users/zhan/Documents

Linux系统稳定性的奥秘:探究其背后的机制与哲学

在计算机操作系统的世界里,Linux以其卓越的稳定性和可靠性著称,成为服务器、嵌入式系统乃至个人电脑用户的首选。那么,是什么造就了Linux如此之高的稳定性呢?本文将深入解析Linux系统稳定性的几个关键因素,揭示其背后的技术哲学与实践。 1. 开源协作的力量Linux是一个开源项目,意味着任何人都可以查看、修改和贡献其源代码。这种开放性吸引了全球成千上万的开发者参与到内核的维护与优化中,形成了

Linux 下的Vim命令宝贝

vim 命令详解(转自:https://www.cnblogs.com/usergaojie/p/4583796.html) vi: Visual Interface 可视化接口 vim: VI iMproved VI增强版 全屏编辑器,模式化编辑器 vim模式: 编辑模式(命令模式)输入模式末行模式 模式转换: 编辑-->输入: i: 在当前光标所在字符的前面,转为输入模式

Linux和Mac分卷压缩

使用 zip 命令压缩文件 使用 zip 命令压缩文件,并结合 split 命令来分卷: zip - largefile | split -b 500k 举例: zip - ./tomcat.dmg |split -b 500k 上述命令将文件 largefile 压缩成 zip 包并分卷成不超过 500k 的文件,分解后文件名默认是 x* ,后缀为 2 位a-z 字母,如 aa、ab。

DDS信号的发生器(验证篇)——FPGA学习笔记8

前言:第一部分详细讲解DDS核心框图,还请读者深入阅读第一部分,以便理解DDS核心思想 三刷小梅哥视频总结! 小梅哥https://www.corecourse.com/lander 一、DDS简介         DDS(Direct Digital Synthesizer)即数字合成器,是一种新型的频率合成技术,具有低成本、低功耗、高分辨率、频率转换时间短、相位连续性好等优点,对数字信