Linux信号集 —— Signal set and using

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

本文主要是介绍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

相关文章

ElasticSearch+Kibana通过Docker部署到Linux服务器中操作方法

《ElasticSearch+Kibana通过Docker部署到Linux服务器中操作方法》本文介绍了Elasticsearch的基本概念,包括文档和字段、索引和映射,还详细描述了如何通过Docker... 目录1、ElasticSearch概念2、ElasticSearch、Kibana和IK分词器部署

Linux流媒体服务器部署流程

《Linux流媒体服务器部署流程》文章详细介绍了流媒体服务器的部署步骤,包括更新系统、安装依赖组件、编译安装Nginx和RTMP模块、配置Nginx和FFmpeg,以及测试流媒体服务器的搭建... 目录流媒体服务器部署部署安装1.更新系统2.安装依赖组件3.解压4.编译安装(添加RTMP和openssl模块

linux下多个硬盘划分到同一挂载点问题

《linux下多个硬盘划分到同一挂载点问题》在Linux系统中,将多个硬盘划分到同一挂载点需要通过逻辑卷管理(LVM)来实现,首先,需要将物理存储设备(如硬盘分区)创建为物理卷,然后,将这些物理卷组成... 目录linux下多个硬盘划分到同一挂载点需要明确的几个概念硬盘插上默认的是非lvm总结Linux下多

linux进程D状态的解决思路分享

《linux进程D状态的解决思路分享》在Linux系统中,进程在内核模式下等待I/O完成时会进入不间断睡眠状态(D状态),这种状态下,进程无法通过普通方式被杀死,本文通过实验模拟了这种状态,并分析了如... 目录1. 问题描述2. 问题分析3. 实验模拟3.1 使用losetup创建一个卷作为pv的磁盘3.

使用C++将处理后的信号保存为PNG和TIFF格式

《使用C++将处理后的信号保存为PNG和TIFF格式》在信号处理领域,我们常常需要将处理结果以图像的形式保存下来,方便后续分析和展示,C++提供了多种库来处理图像数据,本文将介绍如何使用stb_ima... 目录1. PNG格式保存使用stb_imagephp_write库1.1 安装和包含库1.2 代码解

Linux环境变量&&进程地址空间详解

《Linux环境变量&&进程地址空间详解》本文介绍了Linux环境变量、命令行参数、进程地址空间以及Linux内核进程调度队列的相关知识,环境变量是系统运行环境的参数,命令行参数用于传递给程序的参数,... 目录一、初步认识环境变量1.1常见的环境变量1.2环境变量的基本概念二、命令行参数2.1通过命令编程

Linux之进程状态&&进程优先级详解

《Linux之进程状态&&进程优先级详解》文章介绍了操作系统中进程的状态,包括运行状态、阻塞状态和挂起状态,并详细解释了Linux下进程的具体状态及其管理,此外,文章还讨论了进程的优先级、查看和修改进... 目录一、操作系统的进程状态1.1运行状态1.2阻塞状态1.3挂起二、linux下具体的状态三、进程的

Linux编译器--gcc/g++使用方式

《Linux编译器--gcc/g++使用方式》文章主要介绍了C/C++程序的编译过程,包括预编译、编译、汇编和链接四个阶段,并详细解释了每个阶段的作用和具体操作,同时,还介绍了调试和发布版本的概念... 目录一、预编译指令1.1预处理功能1.2指令1.3问题扩展二、编译(生成汇编)三、汇编(生成二进制机器语

Rsnapshot怎么用? 基于Rsync的强大Linux备份工具使用指南

《Rsnapshot怎么用?基于Rsync的强大Linux备份工具使用指南》Rsnapshot不仅可以备份本地文件,还能通过SSH备份远程文件,接下来详细介绍如何安装、配置和使用Rsnaps... Rsnapshot 是一款开源的文件系统快照工具。它结合了 Rsync 和 SSH 的能力,可以帮助你在 li

一文详解Java Condition的await和signal等待通知机制

《一文详解JavaCondition的await和signal等待通知机制》这篇文章主要为大家详细介绍了JavaCondition的await和signal等待通知机制的相关知识,文中的示例代码讲... 目录1. Condition的核心方法2. 使用场景与优势3. 使用流程与规范基本模板生产者-消费者示例