进程间通信以及线程的同步互斥机制

news2024/11/24 12:40:01

1.进程间通信机制

常用的六种通信机制: 管道、消息队列、共享内存、信号灯集、信号、Socket

管道(Pipe)和无名管道(匿名管道):



管道是一种半双工的通信方式,数据只能单向流动,通常用于具有亲缘关系的进程间通信(例如,父子进程)。
无名管道是在内存中开辟的一段缓冲区,一端进程写入数据,另一端进程读取数据。

无名管道的特点:

1.只能用于亲缘间进程的通信

2.无名管道数据半双工的通信的方式

3.无名管道的大小是64K

4.无名管道不能够使用lseek函数(调用会出错 返回 -1)

5.读写的特点

如果读端存在写管道:有多少写多少,直到写满为止(64k)写阻塞,直到管道中腾出新的4K空间,写操作解除阻塞

如果读端不存写管道,管道破裂(SIGPIPE)

如果写端存在读管道:有多少读多少,没有数据的时候阻塞等待

如果写端不存在读管道:有多少读多少,没有数据的时候立即返回(非阻塞)


命名管道(FIFO):

可以用于非亲缘进程间通信,也可以用于亲缘进程间通信有名管道会创建一个管道文件,只需要打开这个文件,进行读写操作即可管道文件本质是在内存上的,在硬盘上的只是一个标识。

有名管道的特点:

1.可以用于任意进程间的通信,不仅限亲缘进程

2.有名管道数据是半双工的通信方式

3.有名管道的大小是64K

4.有名管道不能够使用lseek函数(调用会失败 返回 -1)

5.读写的特点

如果读端存在写管道:有多少写多少,直到写满为止(64k)写阻塞

如果读端不存在写管道

1.读端没有打开,写端在open的位置阻塞

2.读端打开后关闭,管道破裂(SIGPIPE)

如果写端存在读管道:有多少读多少,没有数据的时候阻塞等待

如果写端不存在读管道

1.写端没有打开,读端在open的位置阻塞

2.写端打开后关闭,有多少读多少,没有数据的时候立即返回

信号(Signal):

信号是一种进程间的异步通信方式,用于通知接收进程发生了某种事件,如进程终止、用户输入等。信号处理通常是预定义的。
消息队列(Message Queue):

消息队列也是基于内核实现的,A进程将消息写入消息队列

消息队列中的消息有类型和正文。

B进程可以根据消息的类型从消息队列中将对应类型的消息取走。

消息队列的大小,默认是 16K,

如果消息队列满了,A进程还想向消息队列中写入消息,此时A进程将会阻塞。


共享内存(Shared Memory):

最直接的通信方式之一,允许两个或多个进程直接访问同一块内存区域。速度快,但需要考虑同步问题,如使用互斥锁或信号量。


信号灯集:

信号灯集:又叫做信号量数组,他是实现进程间同步的机制

在一个信号灯集中可以有很多个信号灯,这些信号灯之间工作相互互不干扰。

一般使用时使用的都是二值信号灯


套接字(Socket):

虽然最初用于网络通信,但也可以用于同一台机器上的进程间通信,支持TCP(面向连接、可靠)和UDP(无连接、不可靠)两种通信方式。

2.线程的同步互斥机制:

互斥锁(Mutex):
互斥锁是最基本的同步原则,用于保护临界区(Critical Section),确保同一时间只有一个线程可以访问共享资源。其他试图获取锁的线程会被阻塞,直到持有锁的线程释放锁。


信号量(Semaphore):
信号量可以视为一个计数器,用于控制对公共资源的访问数量。它允许一个或多个线程等待特定条件满足(计数非零)。线程通过wait(P操作)减少计数,通过post(V操作)增加计数。当计数为零时,wait操作会使线程等待。


条件变量(Condition Variable):
条件变量用于线程间的同步,允许线程等待某个条件成立。线程在条件满足前调用wait()函数挂起自身,直到其他线程通过notify()或notify_all()函数通知条件已变成就绪。


读写锁(Read-Write Lock):
读写锁允许多个读线程同时访问共享资源,但在有写线程时会排斥所有读写线程。适用于读多写少的场景,能提高并发效率。


自旋锁(Spin Lock):
自旋锁在获取锁失败时,并不立即放弃CPU,而是在原地循环(自旋)等待锁释放。适用于锁持有时间很短的情况,避免了线程上下文切换的开销。


原子操作(Atomic Operation):
原子操作是不可分割的操作,保证了操作的完整性。在多线程环境下,对变量进行原子操作可以避免数据竞争,如原子加、减、交换等。
 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1835798.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

AI在医学中神奇应用

2022年11月30日,可能将成为一个改变人类历史的日子——美国人工智能开发机构OpenAI推出了聊天机器人ChatGPT-3.5,将人工智能的发展推向了一个新的高度。2023年11月7日,OpenAI首届开发者大会被称为“科技界的春晚”,吸引了全球广大…

前端菜鸡学习日记 -- 关于pnpm

哈咯哇大家,我又来了,最近稍微悠闲一些,所以就趁着这个机会学习一些新的知识,今天就是碰巧遇到了pnm,这个可以看作是npm的升级版本,比npm要快,用起来也更得劲更迅速 官网地址:https…

jupyter使用的一个奇怪bug——SyntaxError: invalid non-printable character U+00A0

bug来由:从其他部分例如kaggle里复制来的代码直接粘贴在jupyter notebook里,每一行代码都会出现: Cell In[5], line 1 warnings.filterwarnings(ignore) ^ SyntaxError: invalid non-printable character U00A0 单元格 In[5],第 …

Rocky Linux 更换CN镜像地址

官方镜像列表&#xff0c;下拉查找 官方镜像列表&#xff1a;https://mirrors.rockylinux.org/mirrormanager/mirrorsCN 开头的站点。 一键更改镜像地址脚本 以下是更改从默认更改到阿里云地址 cat <<EOF>>/RackyLinux_Update_repo.sh #!/bin/bash # -*- codin…

react native中基于webview的腾讯图形验证码

react native中基于webview的腾讯图形验证码 效果实例图第三方库 腾讯验证码 效果实例图 第三方库 npm i react-native-webviewreact-native-webview import React, { useEffect, useState } from react; import { StyleSheet, Text, View } from react-native; import { We…

8.12 矢量图层面要素单一符号使用二(仅渲染中心点)

文章目录 前言仅渲染中心点&#xff08;Centroid fill&#xff09;QGis设置面符号为仅渲染中心点&#xff08;Centroid fill&#xff09;二次开发代码实现仅渲染中心点&#xff08;Centroid fill&#xff09; 总结 前言 本章介绍矢量图层线要素单一符号中仅渲染中心点&#xf…

【三】【QT开发应用】VSQT和QTCreator项目互相转化的方法,QTCreator项目转化VSQT,VSQT转化为QTCreator

VSQT和QTCreator项目互相转化的方法 QTCreator项目转化VSQT 环境变量配置 将qmake.exe所在的目录添加到系统path里面. 转化命令 qmake -tp vc xxx.pro 生成.vcxproj文件 环境变量配置 将qmake.exe所在的目录路径添加到系统path中. 接着用cmd命令行转换,可能出现的问题 …

C++ 70 之 类模版中的成员函数,在类外实现

#include <iostream> #include <string> using namespace std;template<class T1, class T2> class Students10{ public:T1 m_name;T2 m_age;Students10(T1 name, T2 age); // 类内声明 类外实现// {// this->m_name name;// this->m_age …

淘宝文件系统-哈希查找分析

一.框架理解 在淘宝文件系统中&#xff0c;通常会将文件索引存储在一块内存中&#xff0c;这块内存包含了若干个主块&#xff08;Index Block&#xff09;。每个主块中存储着多个文件的索引信息。每个文件的索引按照哈希表的形式进行存储&#xff0c;通过哈希值来定位到具体的文…

QPST的使用

QPST&#xff08;Qualcomm Product Support Tool&#xff09;是一个针对高通芯片开发的传输软件。 下载软件 进行安装 安装后使用&#xff0c;QPSTConfig 可以自动抓取dump的log 使用QFile 刷机

DDPM公式推导(六)

为了整篇文章的完整性&#xff0c;给出文章剩余部分的翻译。这篇博客没有公式推导部分。 4 Experiments 我们在所有实验中设置 T 1000 T1000 T1000&#xff0c;以使采样过程中神经网络评估的次数与之前的工作 [53, 55] 相匹配。我们将前向过程的方差设置为从 β 1 1 0 − …

Redis 6.0新特性详解

Redis 6.0新特性主要有3个&#xff1a;多线程、Client Side Cache、Acls。下面详细说明一下。 1.多线程 redis 6.0 提供了多线程的支持&#xff0c;redis 6 以前的版本&#xff0c;严格来说也是多线程&#xff0c;只不过执行用户命令的请求时单线程模型&#xff0c;还有一些线…

基于YOLOv10深度学习的高密度人脸智能检测与统计系统【python源码+Pyqt5界面+数据集+训练代码】深度学习实战、目标检测

《博主简介》 小伙伴们好&#xff0c;我是阿旭。专注于人工智能、AIGC、python、计算机视觉相关分享研究。 ✌更多学习资源&#xff0c;可关注公-仲-hao:【阿旭算法与机器学习】&#xff0c;共同学习交流~ &#x1f44d;感谢小伙伴们点赞、关注&#xff01; 《------往期经典推…

【PPT设计前沿】2024年PPT新趋势,让你的演示文稿引领潮流!

文章目录 一、简约风格的新诠释二、动态元素与交互性的深度融合三、个性化与定制化的独特展现四、大数据与可视化的创新应用五、绿色环保与可持续性的倡导《PPT完美设计入门与进阶/入门与进阶》图书特色内容简介目录前言/序言 获取方式 随着技术的不断革新和创意设计的蓬勃发展…

注解详解系列 - @ResponseStatus

注解简介 在今天的每日一注解中&#xff0c;我们将探讨ResponseStatus注解。ResponseStatus是Spring框架中的一个注解&#xff0c;用于为控制器方法指定HTTP响应状态码和理由短语。 注解定义 ResponseStatus注解用于标记控制器方法或异常类&#xff0c;以指示HTTP响应的状态码…

【神经网络】基于CNN(卷积神经网络)构建猫狗分类模型

文章目录 解决问题数据集探索性数据分析数据预处理数据集分割数据预处理 构建模型并训练构建模型训练模型 结果分析与评估模型保存结果预测经验总结 解决问题 针对经典猫狗数据集&#xff0c;基于卷积神经网络&#xff0c;构建猫狗二元分类模型&#xff0c;使用数据集进行参数…

我主编的电子技术实验手册(08)——串联电阻分压

本专栏是笔者主编教材&#xff08;图0所示&#xff09;的电子版&#xff0c;依托简易的元器件和仪表安排了30多个实验&#xff0c;主要面向经费不太充足的中高职院校。每个实验都安排了必不可少的【预习知识】&#xff0c;精心设计的【实验步骤】&#xff0c;全面丰富的【思考习…

由于bug造成truncate table卡住问题

客户反应truncate table卡主&#xff0c;检查awr发现多个truncate在awr报告期内一直没执行完&#xff0c;如下&#xff1a; 检查ash&#xff0c;truncate table表的等待事件都是“enq: RO - fast object reuse”和“local write wait” 查找“enq: RO - fast object reuse”&am…

qmt量化交易策略小白学习笔记第35期【qmt编程之指数数据--如何获取指数行情数据】

qmt编程之获取沪深指数数据 qmt更加详细的教程方法&#xff0c;会持续慢慢梳理。 也可找寻博主的历史文章&#xff0c;搜索关键词查看解决方案 &#xff01; 感谢关注&#xff0c;咨询免费开通量化回测与获取实盘权限&#xff0c;欢迎和博主联系&#xff01; 获取指数行情数…

机器学习笔记——无监督学习下的k均值聚类

k均值聚类算法原理 目标是将样本分类 原理&#xff1a;首先随机选择k何点作为中心&#xff0c;然后计算每一个点到中心的聚类&#xff0c;然后计算到每个中心的距离&#xff0c;选择到中心最短距离的那个中心所在的类进行归类&#xff0c;然后更新中心点&#xff0c;一直重复。…