当前位置: 首页 > article >正文

Linux相关概念和易错知识点(52)(基于System V的信号量和消息队列)

目录1、System V信号量1信号量的本质与核心原理2PV原语均为原子操作a. P原语申请资源b. V原语归还资源3System V信号量接口a. 创建信号量集 semgetb. 控制信号量 semctlc. PV操作 semop4信号量管理2、System V 消息队列1消息队列特点2消息队列接口函数a. 创建 / 获取消息队列 msggetb. 消息队列控制 msgctlc. 发送消息 msgsndd. 接收消息 msgrcv3命令行管理之前我分享过基于System V的共享内存的使用上篇文章也引入mmap分析了其底层实现即共享映射文件缓冲区使得不同进程看到同一块区域本篇文章会继续分享System V标准下的信号量和消息队列。整体难度不大不需记忆接口了解即可因此本文借助AI生成仅做简单记录和介绍。1、System V信号量1信号量的本质与核心原理无论是POSIX还是System V标准下信号量本质是一个计数器即资源的预定机制主要用于进程间同步与互斥管理在用环形队列实现生产者消费者模型中有很大用处。信号量操作分为P操作申请资源与V操作归还资源。信号量计数器s的含义s 0表示当前可用资源的个数s 0表示无可用资源且无等待进程s 0表示无可用资源|s|为等待队列中进程的个数内核中信号量可由结构体表示structsemaphore{intvalue;structPCB*queue;};2PV原语均为原子操作a. P原语申请资源执行 value–判断 value 0若成立说明资源不足将当前进程加入等待队列并阻塞进程调度切换等待被唤醒voidP(structsemaphore*sem){sem-value--;if(sem-value0){add_to_queue(sem-queue,current_process);block_current_process();}}b. V原语归还资源执行 value判断 value 0若成立说明有进程在等待从等待队列唤醒一个进程至就绪态唤醒后的进程可重新尝试申请信号量voidV(structsemaphore*sem){sem-value;if(sem-value0){structPCB*procremove_from_queue(sem-queue);wake_up_process(proc);}}3System V信号量接口a. 创建信号量集 semgetintsemget(key_t key,intnsems,intsemflg);key唯一标识与共享内存规则一致nsems信号量集中信号量的个数semflg支持 IPC_CREAT 与 IPC_EXCL返回值成功返回 semid失败返回 -1b. 控制信号量 semctlintsemctl(intsemid,intsemnum,intcmd,...);semid信号量集标识符semnum信号量下标从0开始cmdSETVAL初始化单个信号量该操作不具备原子性IPC_RMID删除整个信号量集第二个参数无意义返回值失败返回 -1c. PV操作 semopintsemop(intsemid,structsembuf*sops,size_t nsops);sops操作结构体数组nsops数组长度可同时对多个信号量执行原子操作例如一个P、一个V返回值成功 0失败 -14信号量管理查看信号量ipcs -s删除信号量ipcrm -sSystem V 信号量生命周期随内核进程退出不会自动释放必须手动删除通常在析构函数中完成释放逻辑。2、System V 消息队列1消息队列特点a.允许任意进程间通信消息队列是内核提供的 System V IPC 机制不要求进程之间存在亲缘关系只要多个进程通过同一个 key 访问同一个消息队列即可实现数据收发支持无关联进程间通信。b.消息自带类型标识可按类型选择性接收每条消息必须以一个 long 类型的消息类型字段开头接收方可以指定只接收某一类型的消息不匹配类型的消息会继续保留在队列中也可以不指定类型直接读取最早消息实现消息分类与分发。c.支持全双工通信通信双方可以使用不同消息类型分别进行发送和接收无需切换读写方向双向通信互不干扰天然实现全双工。d.生命周期随内核消息队列创建后会持续存在于内核中进程退出不会自动删除只有通过调用msgctl(IPC_RMID) 或系统重启才会销毁。e.面向数据块传输以消息为单位传输每条消息独立不同于管道的字节流传输边界清晰。2消息队列接口函数a. 创建 / 获取消息队列 msggetintmsgget(key_t key,intmsgflg);key消息队列的唯一标识符可通过 ftok 生成或手动指定msgflg权限位 创建标志IPC_CREAT队列不存在则创建存在则返回已存在队列 IDIPC_EXCL与 IPC_CREAT 配合使用队列已存在则报错确保新建队列例IPC_CREAT | 0666返回值成功返回消息队列 ID msqid失败返回 -1b. 消息队列控制 msgctlintmsgctl(intmsqid,intcmd,structmsqid_ds*buf);cmdIPC_RMID删除消息队列此时 buf 传 NULLIPC_STAT获取队列属性信息存入 bufIPC_SET设置队列属性常用于删除队列msgctl(msqid, IPC_RMID, NULL);c. 发送消息 msgsndintmsgsnd(intmsqid,constvoid*msgp,size_t msgsz,intmsgflg);msgp指向自定义消息结构体指针结构体必须以 long mtype 开头msgsz消息数据部分长度不包含 mtype 字段msgflg一般为 0阻塞发送或 IPC_NOWAIT非阻塞消息结构体示例structmsgbuf{longmtype;charmtext[1024];};d. 接收消息 msgrcvintmsgrcv(intmsqid,void*msgp,size_t msgsz,longmsgtyp,intmsgflg);msgtyp要接收的消息类型0接收队列中第一条任意类型消息0接收指定类型的第一条消息0接收类型 ≤ |msgtyp| 的最小类型消息msgsz数据缓冲区大小msgflg一般为 0阻塞或 IPC_NOWAIT、MSG_NOERROR 等3命令行管理查看消息队列ipcs -q删除消息队列ipcrm -q msqid

相关文章:

Linux相关概念和易错知识点(52)(基于System V的信号量和消息队列)

目录1、System V信号量(1)信号量的本质与核心原理(2)PV原语(均为原子操作)a. P原语(申请资源)b. V原语(归还资源)(3)System V信号量接…...

MCP3221 12位I²C ADC驱动设计与精度优化实战

1. MCP3221 12位IC模数转换器底层驱动技术解析MCP3221是Microchip公司推出的超低功耗、单通道、12位分辨率的串行模数转换器(ADC),采用标准IC总线接口,工作电压范围宽达2.7V至5.0V,静态电流典型值仅仅为1.5μA&#xf…...

GraalVM Native Image内存模型深度解构:从Class Initialization Order到Heap Snapshot Graph的7层映射关系图

第一章:GraalVM Native Image内存模型的理论基石与设计哲学GraalVM Native Image 的内存模型并非传统 JVM 堆内存的简单移植,而是基于静态分析与封闭世界假设(Closed World Assumption)重构的全新范式。它在编译期即确定所有可达类…...

GLM技术复盘:篇论文深度解读智谱模型家族菏

开发个什么Skill呢? 通过 Skill,我们可以将某些能力进行模块化封装,从而实现特定的工作流编排、专家领域知识沉淀以及各类工具的集成。 这里我打算来一次“套娃式”的实践:创建一个用于自动生成 Skill 的 Skill,一是用…...

FastAPI子应用挂载:别再让root_path坑你一夜卤

Julia(julialang.org)由Stefan Karpinski、Jeff Bezanson等在2009年创建,目标是融合Python的易用性、C的高性能、R的统计能力、Matlab的科学计算生态。 其核心设计哲学是: 高性能:编译型语言(JIT&#xf…...

AI时代的算法思维:大经典排序学习弥

引言 在现代软件开发中,性能始终是衡量应用质量的重要指标之一。无论是企业级应用、云服务还是桌面程序,性能优化都能显著提升用户体验、降低基础设施成本并增强系统的可扩展性。对于使用 C# 开发的应用程序而言,性能优化涉及多个层面&#x…...

粉紫系超人气月兔铃仙仁

1 安装与初始化 # 全局安装 OpenSpec npm install -g fission-ai/openspeclatest # 在项目目录下初始化 cd /path/to/your-project openspec init 初始化时,OpenSpec 会提示你选择使用的 AI 工具(Claude Code、Cursor、Trae、Qoder 等)。 3 O…...

潘多拉魔盒上的封条:当AI强到连“造物主”都感到恐惧

梁敬彬梁敬弘兄弟出品 引言 2026年的春天,AI的狂飙似乎没有任何减速的迹象。各路媒体依然在为大模型跑分榜上的微小超越而摇旗呐喊,资本市场依然在为算力中心的落成而陷入狂热。在这场看似永远不会停歇的技术飙车中,几乎所有人都坚信一个朴…...

SpringCloud-Stream + RocketMQ/Kafka

一、核心认知:Spring Cloud Stream 是什么?解决什么问题?1.1 基本定义Spring Cloud Stream 是 Spring 生态下的「消息驱动微服务框架」,基于 Spring Boot 构建,核心定位是「统一消息中间件接口,简化消息驱动…...

绵阳高新区小学晚托自习

在绵阳石桥铺,孩子在家写作业拖拉磨蹭、坐不住,手机干扰不断等问题让家长们头疼不已。而分小全AI智能学习体验中心旗下的分小全智习室,正是解决这些问题的专业之选。督学老师资质分小全智习室的督学老师均具备师范类或教育学专业背景&#xf…...

别再踩坑了!SQL Server数据类型那点事儿,看懂这篇少背三个锅竟

从0构建WAV文件:读懂计算机文件的本质 虽然接触计算机有一段时间了,但是我的视野一直局限于一个较小的范围之内,往往只能看到于算法竞赛相关的内容,计算机各种文件在我看来十分复杂,认为构建他们并能达到目的是一件困难…...

P4561 [JXOI2018] 排序问题

题意 有一个序列,现在要在结尾加上 mmm 个 [l,r][l,r][l,r] 之间的数,求在所有方案中,猴子排序(每次随机一个排列,检查是否有序)的次数期望最大次数。 思路 假设最终的序列中数 iii 出现的次数是 cic_ici​…...

免疫治疗新视角:CD47 (分化簇47) 信号通路机制与药物研发技术综述

在生物制药与免疫学领域,CD47 (分化簇47) 作为连接先天免疫与适应性免疫的关键节点,近年来备受关注。作为一种广泛表达的跨膜糖蛋白,它通过复杂的信号轴调控免疫细胞的吞噬行为。本文将深入剖析CD47的作用机制、当前药物研发的临床进展以及未…...

linux文件,IO,缓存,动\静函数库

1.文件IO与标准IO的区别文件IO:直接调用内核提供的系统调用函数,头文件是unistd.h标准IO:间接调用系统调用函数,头文件是stdio.h缓存的概念1.程序的缓存就是用户空间的缓存。2.每打开一个文件,在内核中开辟一个缓存即为…...

【Java】通过Mybatis Plus自带的方式,实现公共字段自动填充。

通过Mybatis Plus自带的方式,实现公共字段自动填充。 第一步,创建一个公共字段类,加上对应注解。 Data public class BaseEntity implements Serializable {Serialprivate static final long serialVersionUID 1L;TableField(value "c…...

《道德经》第九章

本章以持而盈之功成身退为核心,是道家保身、持满、长久的警示章。老子用“持盈、揣锐、富贵而骄”三组世俗常见困境,指出过刚则折、过满则溢、过骄则亡的天道规律,最终以“功成身退,天之道”点破最高处世心法,是全书最…...

设置echarts 图例为长方形

在 ECharts 中,要将图例(legend)的 标记(icon) 设置为 长方形(矩形),可以通过 legend 配置项中的 icon 属性来实现。✅ 方法:使用 icon: rect ECharts 内置了多种图例标记…...

系统设计面试通关秘籍:从场景分析到微服务拆分的核心思路

系统设计面试通关秘籍:从场景分析到微服务拆分的核心思路一、Scenario场景分析:打好系统设计的基础牌🔍 先定功能:抓核心,舍冗余📊 再估流量:从MAU到QPS,做有依据的推算⚙️ 流量决定…...

OpenClaw自动化测试实践:gemma-3-12b-it驱动Python脚本批量执行

OpenClaw自动化测试实践:gemma-3-12b-it驱动Python脚本批量执行 1. 为什么选择OpenClawgemma做测试自动化? 上个月重构一个爬虫项目时,我遇到了测试脚本管理的噩梦——每次修改核心逻辑后,都需要手动执行十几个测试用例&#xf…...

【51 单片机入门到进阶】08 入门:51单片机定时器0/1使用详解

1,定时器中断核心基础总览 定时器中断:定时器计数溢出时,硬件自动触发中断,CPU 暂停主程序执行中断服务函数,是单片机定时控制、延时、周期任务的核心方式。中断名称中断号入口地址核心控制寄存器中断标志定时器 0 中断…...

stock-sdk-mcp 的实践整理绰

一、什么是urllib3? urllib3 是一个用于处理 HTTP 请求和连接池的强大、用户友好的 Python 库。 它可以帮助你: 发送各种 HTTP 请求(GET, POST, PUT, DELETE等)。 管理连接池,提高网络请求效率。 处理重试和重定向。 支…...

Programmable-Air开源气动控制库底层驱动解析

1. Programmable-Air 开源控制库深度解析:面向嵌入式工程师的底层驱动实践指南Programmable-Air 是一款基于 Crowdfunding 平台 CrowdSupply 成功孵化的开源气动控制硬件平台,其核心价值在于将传统工业级气动执行器(泵、阀、压力传感器&#…...

千问3.5-9B+OpenClaw成本对比:自建模型VS商业API

千问3.5-9BOpenClaw成本对比:自建模型VS商业API 1. 为什么需要关注OpenClaw的token消耗 去年冬天,当我第一次用OpenClaw自动整理全年会议纪要时,看着控制台不断刷新的token消耗记录,手指不自觉地敲起了桌子——这个看似简单的任…...

FreakStudio泄

环境安装 pip install keystone-engine capstone unicorn 这3个工具用法极其简单,下面通过示例来演示其用法。 Keystone 示例 from keystone import * CODE b"INC ECX; ADD EDX, ECX" try:ks Ks(KS_ARCH_X86, KS_MODE_64)encoding, count ks.asm(CODE)…...

JavaScript中BigInt与Number类型混用的报错机制

JavaScript中BigInt与Number不能直接混合运算&#xff0c;会立即抛出TypeError&#xff1b;所有涉及两者混合的算术和关系操作&#xff08;如1n1、10n<5&#xff09;均报错&#xff0c;仅和不报错但返回false。JavaScript中BigInt与Number不能直接混合运算&#xff0c;会立即…...

ESP居然能当 DNS 服务器用?内含NCSI欺骗和DNS劫持实现罢

前言 Kubernetes 本身并不复杂&#xff0c;是我们把它搞复杂的。无论是刻意为之还是那种虽然出于好意却将优雅的原语堆砌成 鲁布戈德堡机械 的狂热。平台最初提供的 ReplicaSets、Services、ConfigMaps&#xff0c;这些基础组件简单直接&#xff0c;甚至显得有些枯燥。但后来我…...

告别格式烦恼:如何用Chrome扩展一键转换网页图片格式?

告别格式烦恼&#xff1a;如何用Chrome扩展一键转换网页图片格式&#xff1f; 【免费下载链接】Save-Image-as-Type Save Image as Type is an chrome extension which add Save as PNG / JPG / WebP to the context menu of image. 项目地址: https://gitcode.com/gh_mirror…...

毕业设计实战:基于Java+MySQL的C2C商务网站设计与实现指南

毕业设计实战&#xff1a;基于JavaMySQL的C2C商务网站设计与实现指南 在开发“基于JavaMySQL的C2C商务网站”毕业设计时&#xff0c;我曾因商品订单表未通过用户ID、商品ID与收货地址ID三外键关联踩过关键坑——初期设计订单表时&#xff0c;仅记录了订单号、总价、下单时间等基…...

Python编程第09课:Python列表(List)操作完全手册

前言&#xff1a;Python最常用的数据结构 列表是Python中最常用、最灵活的数据结构。它就像一个容器&#xff0c;可以存储任意类型的元素&#xff0c;并且可以随时添加、删除或修改元素。无论是处理数据、实现算法还是构建应用程序&#xff0c;列表都是你离不开的工具。 本课程…...

OpenClaw模型量化指南:压缩Qwen2.5-VL-7B提升本地运行效率

OpenClaw模型量化指南&#xff1a;压缩Qwen2.5-VL-7B提升本地运行效率 1. 为什么需要量化多模态大模型 当我第一次在本地MacBook Pro上尝试运行Qwen2.5-VL-7B时&#xff0c;风扇立刻开始狂转&#xff0c;16GB内存几乎被吃满&#xff0c;模型加载就花了近3分钟。这种体验让我意…...