Linux---进程间通信

一、进程间通信的目的

1、数据传输:一个进程需要将它的数据发送给另一个进程

2、资源共享:多个进程之间共享同样的资源。

3、通知事件:一个进程需要向另一个或另一组进程发送消息,通知它(它们)发生了某种事件(如:进程终止时要通知父进程)

4、进程控制:有些进程希望完全控制另一个进程的执行,此时控制进程希望能够拦截另一个进程的所有陷入和异常,并能够及时的知道它的状态改变。

二、进程间通信发展

管道

System V进程间通信---一台机器内部。

POSIX进程间通信。---进程间进行跨网络通信

三、进程间通信分类

管道:(通信标准的名称)

1、匿名管道pipe

2、命名管道

System V IPC(通信标准的名称)

1、System V消息队列

2、System V共享内存

3、System V信号量

POSIX IPC(通信标准的名称)

1、消息队列

2、共享内存

3、信号量

4、互斥量

5、条件变量

6、读写锁

四、进程间通信怎么做?

进程间是具有独立性的!

进程的本质

就是首先让不同的进程,先要看到同一份"资源"(由操作系统提供)。

匿名管道通信原理

仿照文件,设计了一套通信标准,

fork的时候,file要进行拷贝,管道是单向通信(单工通信)的。比如:永远都是父进程给子进程写消息,或者永远都是子进程给父进程写消息。

全双工通信:eg.吵架的时候

半双工通信:人类正常沟通

单工通信:上课的时候(比如老师一直讲课)

注意:管道是一个纯内存级的文件,不需要打开磁盘文件之类的!没有路径,匿名管道。

管道是类Unix中最古老的进程间通信的形式。

创建管道

pipe

步骤:创建管道文件;fork;关闭读写段,子w,父r。

pipefd[0]是读,pipe[1]是写。

相关推荐
武子康13 小时前
调查研究-138 全球机器人产业深度调研报告【01 篇】:市场规模、竞争格局与商业化成熟 2026
服务器·数据库·ai·chatgpt·机器人·具身智能
_kerneler13 小时前
[qemu+kvm]: trap 寄存器脱敏优化方法
linux
猫猫的小茶馆14 小时前
【Python】函数与模块化编程
linux·开发语言·arm开发·驱动开发·python·stm32
xhbh66614 小时前
代理ARP (Proxy ARP) 是如何实现跨网段通信的?在Linux下如何配置?
服务器·网络·智能路由器·端口映射·映射
神奇椰子15 小时前
[特殊字符] 服务器搭建网站完整教程
运维·服务器
慧都小妮子15 小时前
告别看图抓数据:DeviceXPlorer OPC Server 助力数据自动化管理
运维·物联网·自动化·takebishi·dxpserver·opc server
Wpa.wk15 小时前
APP自动化-Appium环境安装
运维·appium·自动化
快乐的哈士奇15 小时前
LangFuse 自托管实战:选型理由、Docker 部署与常用配置全解析
运维·人工智能·docker·容器
数智化管理手记15 小时前
精益生产3步实操,让现场从混乱变标杆
大数据·运维·网络·人工智能·精益工程
代码AC不AC15 小时前
【Linux】线程概念
linux·线程