Linux 信号集与信号掩码
目录
一、引言
二、信号集是什么
三、信号集关键函数
1.信号集的创建与初始化
2.信号的添加与删除
3.信号集的阻塞与解除阻塞
四、信号集实际应用场景
五、信号掩码的作用
六、信号掩码相关函数
1.sigprocmask 函数
2.sigemptyset 和 sigfillset 函数
七、信号掩码注意事项
八、总结
一、引言
在 Linux 系统编程中,信号集和信号掩码是处理信号机制不可或缺的部分。它们能够让开发者精细地控制进程对信号的接收和处理,对程序的稳定性和可靠性有着至关重要的作用。信号是一种软中断,用于通知进程发生了特定的事件。例如,当用户在终端按下 Ctrl + C 时,内核会向当前前台进程发送 SIGINT 信号,进程收到此信号后通常会终止运行。
二、信号集是什么
信号集本质上是一个数据结构,用于表示多个信号的集合。在 Linux 中,信号是用于进程间异步通知的一种机制,比如当子进程结束时,会向父进程发送 SIGCHLD 信号。而信号集就是用来对这些信号进行集中管理和操作的,常见的操作包括信号的添加、删除以及判断某个信号是否在集合中。
三、信号集关键函数
1.信号集的创建与初始化
使用 sigemptyset 函数可以创建一个空的信号集,即将信号集中的所有信号都设置为未决状态。与之相对的是 sigfillset 函数,它会将所有信号添加到信号集中,使其处于阻塞状态。例如:
sigset_t set;
sigemptyset(&set); // 创建空信号集
sigaddset(&set, SIGINT); // 向信号集中添加 SIGINT 信号
2.信号的添加与删除
sigaddset 函数用于向信号集中添加指定的信号,而 sigdelset 函数则用于从信号集中删除指定的信号。通过这两个函数,可以灵活地定制信号集的组成。
3.信号集的阻塞与解除阻塞
sigprocmask 函数是控制信号阻塞的关键。它可以根据给定的信号集,阻塞或解除阻塞相应的信号。例如,以下代码可以阻塞 SIGINT 信号:
sigset_t block_set;
sigemptyset(&block_set);
sigaddset(&block_set, SIGINT);
sigprocmask(SIG_BLOCK, &block_set, NULL);
当不需要阻塞时,可以使用 SIG_UNBLOCK 操作来解除阻塞。
四、信号集实际应用场景
信号集在很多系统编程场景中都有广泛应用。比如在服务器编程中,父进程创建多个子进程来处理客户端请求时,父进程可以使用信号集来阻塞 SIGCHLD 信号,然后在合适的时候通过 sigwait 等函数来等待子进程结束的信号,从而避免僵尸进程的产生,并且能够高效地回收子进程资源。
五、信号掩码的作用
信号掩码主要用于控制进程对信号的响应行为。当一个信号被添加到进程的信号掩码中时,进程在当前时刻将暂时不会接收到该信号,即信号被阻塞。这在一些特定场景下非常有用,例如在进程执行关键代码段时,不希望被某些信号中断,就可以将这些信号添加到信号掩码中,待关键代码段执行完毕后,再解除对这些信号的阻塞,从而保证程序的稳定性和数据的一致性。
六、信号掩码相关函数
1.sigprocmask 函数
这是操作信号掩码的核心函数。它可以用来设置、获取或修改进程的信号掩码。函数原型如下:
int sigprocmask(int how, const sigset_t *set, sigset_t *oldset);
how 参数指定了操作方式,常见的取值有:
- SIG_BLOCK:将 set 指向的信号集中的信号添加到当前信号掩码中,即阻塞这些信号。
- SIG_UNBLOCK:将 set 指向的信号集中的信号从当前信号掩码中移除,即解除对这些信号的阻塞。
- SIG_SETMASK:直接将当前信号掩码设置为 set 指向的信号集。
set 参数是一个指向信号集的指针,用于指定要操作的信号集合。如果不需要改变信号掩码,该参数可以设置为 NULL。
oldset 参数也是一个指向信号集的指针,用于保存原有的信号掩码。如果不需要获取原信号掩码,该参数也可以设置为 NULL。
2.sigemptyset 和 sigfillset 函数
在使用 sigprocmask 函数前,通常需要先创建一个信号集,并通过 sigemptyset 函数将其初始化为空集(即不包含任何信号),或者使用 sigfillset 函数将其初始化为包含所有信号的集合,然后根据具体需求使用 sigaddset 或 sigdelset 函数向信号集中添加或删除特定的信号。
例如,以下代码片段展示了如何使用这些函数来阻塞 SIGINT 信号,并在一段时间后解除阻塞:
#include <stdio.h>
#include <signal.h>
#include <unistd.h>int main() {sigset_t block_set, old_set;// 初始化信号集为空集sigemptyset(&block_set);// 将 SIGINT 信号添加到要阻塞的信号集中sigaddset(&block_set, SIGINT);// 设置信号掩码,阻塞 SIGINT 信号,并保存原信号掩码sigprocmask(SIG_BLOCK, &block_set, &old_set);printf("SIGINT is blocked. Press Ctrl+C to test...\n");sleep(5);// 恢复原信号掩码,解除对 SIGINT 的阻塞sigprocmask(SIG_SETMASK, &old_set, NULL);printf("SIGINT is unblocked.\n");return 0;
}
七、信号掩码注意事项
在使用信号掩码时,需要谨慎考虑阻塞信号的时长和范围。过度或不合理地阻塞信号可能会导致进程错过重要的事件通知,从而影响程序的正常运行。例如,如果长时间阻塞与进程终止相关的信号(如 SIGTERM),可能会使进程在需要被关闭时无法及时响应,造成资源无法释放等问题。同时,在多线程环境下,信号掩码的操作会影响整个进程,而不仅仅是当前线程,因此需要更加小心地处理信号掩码,避免对其他线程的信号处理产生意外影响。
八、总结
信号集和信号掩码是Linux信号处理中的重要工具。信号集提供了一种方便的方式来组织和管理信号,而信号掩码则允许我们精确地控制进程对信号的接收。理解和掌握它们的概念和操作方法,能够帮助我们更好地编写健壮、高效的Linux程序,提升程序在复杂环境下应对各种事件的能力。
相关文章:

Linux 信号集与信号掩码
目录 一、引言 二、信号集是什么 三、信号集关键函数 1.信号集的创建与初始化 2.信号的添加与删除 3.信号集的阻塞与解除阻塞 四、信号集实际应用场景 五、信号掩码的作用 六、信号掩码相关函数 1.sigprocmask 函数 2.sigemptyset 和 sigfillset 函数 七、信号掩码注…...

如何设置Edge浏览器访问软件
使用Edge浏览器访问分销ERP A\V系列软件时会出现各种报错,如何设置Edge浏览器使其正常访问,请看下面的具体操作。 一、打开Edge浏览器,点击右上角的 设置及其他,如图: 二、在弹出界面中,点击 扩展ÿ…...

DL笔记:旋转编码RoPE
1 背景 由于计算资源限制,目前的LLM大多在较短的上下文长度中进行训练,在推理中,如果超出预训练的长度,模型的性能将会显著降低 ——>需要一个可提供外推性的位置编码最经典的绝对位置编码就是原始Transformer中的那个sinusoi…...
C语言自定义类型与文件操作
构造类型 枚举类型 若定义不相关的常量使用宏定义;若定义一组相关的常量使用枚举。switch中case后访问的就是枚举。 定义: 我们一般情况下定义常量使用宏定义(#define),宏定义适合没有关联关系的常量;但有时需要对一组有关联关系…...
《计算机网络A》单选题-复习题库解析-3
目录 106、MAN通常是指( ) 107、下列因素中,不会影响信道数据传输速率的是( ) 108、以太网交换机进行转发决策时使用的PDU地址是( ) 109、下列机制中,可以解决因数据帧丢失而…...

VM虚拟机配置ubuntu网络
目录 桥接模式 NAT模式 桥接模式 特点:ubuntu的IP地址与主机IP的ip地址不同 第一部分:VM虚拟机给ubuntu的网络适配器,调为桥接模式 第二部分:保证所桥接的网络可以上网 第三部分:ubuntu使用DHCP(默认&…...
【每日学点鸿蒙知识】Web高度适配、变量声明规范、动画取消、签名文件、包体积优化相关
1、HarmonyOS Web页面高度适配? 在Web页面设置高度100%时,发现和Web控件的高度不一致,这个需要设置什么可以达到页面高度和Web容器高度一致 目前只支持两种web布局模式,分别为Web布局跟随系统WebLayoutMode.NONE和Web基于页面大…...

uniapp使用ucharts组件
1.ucharts准备 有两种使用方式:一种是在uni的插件市场下载(组件化开发)。一种是手动引入ucharts包。官方都封装好组件了,我们不用岂不是浪费。 直接去dcloud插件市场(DCloud 插件市场)找,第一…...

LabVIEW工程师的未来发展
对于LabVIEW工程师以及更广义的编程从业者(包括“高级民工”码农)来说,随着AI技术和软件编程的逐步成熟,确实面临一些新的挑战和机遇。以下是对此问题的深入分析和未来方向的建议: 现状分析:技术过剩与竞争…...
java的bio、nio、aio 以及操作系统的select、poll、epoll
在 Java 和其他编程语言中,I/O 模型的选择对网络应用的性能和可扩展性有着重要影响。以下是 BIO(Blocking I/O)、NIO(Non-blocking I/O)、AIO(Asynchronous I/O),以及操作系统级别的…...

2024 年发布的 Android AI 手机都有什么功能?
大家好,我是拭心。 2024 年是 AI 快速发展的一年,这一年 AI 再获诺贝尔奖,微软/苹果/谷歌等巨头纷纷拥抱 AI,多款强大的 AI 手机进入我们的生活。 今年全球 16% 的智能手机出货量为 AI 手机,到 2028 年,这…...
RLHF,LM模型
LLM(Large Language Model) RLHF(Reinforcement Learning from Human Feedback),即以强化学习方式依据人类反馈优化语言模型。 RLHF思想:使用强化学习的方式直接优化带有人类反馈的语言模型。RLHF使得在一般文本数据语料库上训练的语言模型能与复杂的人类价值观对齐。 R…...

【机器学习】工业 4.0 下机器学习如何驱动智能制造升级
我的个人主页 我的领域:人工智能篇,希望能帮助到大家!!!👍点赞 收藏❤ 随着科技的飞速发展,工业 4.0 浪潮正席卷全球制造业,而机器学习作为这一变革中的关键技术,正以前…...
REST与RPC的对比:从性能到扩展性的全面分析
在微服务架构中,服务间通信是核心问题之一。常见的两种通信方式是REST(Representational State Transfer)和RPC(Remote Procedure Call)。它们各有优缺点,适用于不同场景。本文将从性能、扩展性、兼容性和开…...
MATLAB中将MAT文件转换为Excel文件
MATLAB中将MAT文件转换为Excel文件 MATLAB提供了多种方法将MAT文件中的数据导出到Excel文件中。下面介绍几种常用的方法: 1. 使用 writetable 函数 优点: 功能强大,可以灵活控制输出格式。用法: data load(your_data.mat); …...
leetcode hot 100 跳跃游戏2
45. 跳跃游戏 II 已解答 中等 相关标签 相关企业 给定一个长度为 n 的 0 索引整数数组 nums。初始位置为 nums[0]。 每个元素 nums[i] 表示从索引 i 向前跳转的最大长度。换句话说,如果你在 nums[i] 处,你可以跳转到任意 nums[i j] 处: 0 < j…...

【Cesium】八、Cesium 默认地图不显示,不加载默认Bing地图
文章目录 前言实现方法App.vue 前言 Cesium 默认加载的地图是bing地图,个人认为请求bing地图会收到网络限制,导致地图资源下载很慢,所以设置默认不加载bing地图(后续我使用的是天地图) 参考文章: cesium …...

【新方法】通过清华镜像源加速 PyTorch GPU 2.5安装及 CUDA 版本选择指南
下面详细介绍所提到的两条命令,它们的作用及如何在你的 Python 环境中加速 PyTorch 等库的安装。 1. 设置清华镜像源 pip config set global.index-url https://pypi.tuna.tsinghua.edu.cn/simple这条命令的作用是将 pip (Python 的包管理工具…...
MySQL的sql操作有哪些
MySQL 的 SQL 操作可以分为几个主要类别,每个类别包含了一系列的语句,用于执行不同的数据库操作: 数据查询语言(DQL) SELECT:用于从一个或多个表中检索数据。可以使用 WHERE 子句进行条件筛选,…...

ArcGIS计算矢量要素集中每一个面的遥感影像平均值、最大值等统计指标
本文介绍在ArcMap软件中,基于矢量面要素集,计算在其中每一个面区域内,遥感影像的像元个数、平均值、总和等统计值,并将统计信息附加到矢量图层的属性表中的方法。 首先,明确一下本文的需求。现在有一个矢量面要素集&am…...
椭圆曲线密码学(ECC)
一、ECC算法概述 椭圆曲线密码学(Elliptic Curve Cryptography)是基于椭圆曲线数学理论的公钥密码系统,由Neal Koblitz和Victor Miller在1985年独立提出。相比RSA,ECC在相同安全强度下密钥更短(256位ECC ≈ 3072位RSA…...

云启出海,智联未来|阿里云网络「企业出海」系列客户沙龙上海站圆满落地
借阿里云中企出海大会的东风,以**「云启出海,智联未来|打造安全可靠的出海云网络引擎」为主题的阿里云企业出海客户沙龙云网络&安全专场于5.28日下午在上海顺利举办,现场吸引了来自携程、小红书、米哈游、哔哩哔哩、波克城市、…...
Java如何权衡是使用无序的数组还是有序的数组
在 Java 中,选择有序数组还是无序数组取决于具体场景的性能需求与操作特点。以下是关键权衡因素及决策指南: ⚖️ 核心权衡维度 维度有序数组无序数组查询性能二分查找 O(log n) ✅线性扫描 O(n) ❌插入/删除需移位维护顺序 O(n) ❌直接操作尾部 O(1) ✅内存开销与无序数组相…...
mongodb源码分析session执行handleRequest命令find过程
mongo/transport/service_state_machine.cpp已经分析startSession创建ASIOSession过程,并且验证connection是否超过限制ASIOSession和connection是循环接受客户端命令,把数据流转换成Message,状态转变流程是:State::Created 》 St…...

渗透实战PortSwigger靶场-XSS Lab 14:大多数标签和属性被阻止
<script>标签被拦截 我们需要把全部可用的 tag 和 event 进行暴力破解 XSS cheat sheet: https://portswigger.net/web-security/cross-site-scripting/cheat-sheet 通过爆破发现body可以用 再把全部 events 放进去爆破 这些 event 全部可用 <body onres…...
将对透视变换后的图像使用Otsu进行阈值化,来分离黑色和白色像素。这句话中的Otsu是什么意思?
Otsu 是一种自动阈值化方法,用于将图像分割为前景和背景。它通过最小化图像的类内方差或等价地最大化类间方差来选择最佳阈值。这种方法特别适用于图像的二值化处理,能够自动确定一个阈值,将图像中的像素分为黑色和白色两类。 Otsu 方法的原…...
Spring AI 入门:Java 开发者的生成式 AI 实践之路
一、Spring AI 简介 在人工智能技术快速迭代的今天,Spring AI 作为 Spring 生态系统的新生力量,正在成为 Java 开发者拥抱生成式 AI 的最佳选择。该框架通过模块化设计实现了与主流 AI 服务(如 OpenAI、Anthropic)的无缝对接&…...

【开发技术】.Net使用FFmpeg视频特定帧上绘制内容
目录 一、目的 二、解决方案 2.1 什么是FFmpeg 2.2 FFmpeg主要功能 2.3 使用Xabe.FFmpeg调用FFmpeg功能 2.4 使用 FFmpeg 的 drawbox 滤镜来绘制 ROI 三、总结 一、目的 当前市场上有很多目标检测智能识别的相关算法,当前调用一个医疗行业的AI识别算法后返回…...
laravel8+vue3.0+element-plus搭建方法
创建 laravel8 项目 composer create-project --prefer-dist laravel/laravel laravel8 8.* 安装 laravel/ui composer require laravel/ui 修改 package.json 文件 "devDependencies": {"vue/compiler-sfc": "^3.0.7","axios": …...

听写流程自动化实践,轻量级教育辅助
随着智能教育工具的发展,越来越多的传统学习方式正在被数字化、自动化所优化。听写作为语文、英语等学科中重要的基础训练形式,也迎来了更高效的解决方案。 这是一款轻量但功能强大的听写辅助工具。它是基于本地词库与可选在线语音引擎构建,…...