Linux系统编程 80 进程间的通信方式

学习笔记
在linux环境下,进程地址空间相互独立的,每个进程各自有不同的用户地址空间。
任何一个进程的全局变量在另一个进程中都看不到,所以进程和进程之间不能相互访问。
要交换数据,必须通过内核,在内核中开辟一块缓冲区,进程1把数据从用户空间拷贝到
内核缓冲区,进程2再从内核缓冲区把数据拷贝走,内核提供的这种机制称为进程间的通信。
IPC(interprocesscommunication).
进程地址空间是独立的。
父进程和子进程之间搭建桥梁。
这个桥梁就是进程间通信IPC


进程间通信的原理:

0g-3g:是用户空间
3g-4g:是内核空间

操作系统的内核空间是共享的。所以进程之间有相同的内核空间。
桥梁的本质:内核空间中的一块缓冲区。

图1

在进程间完成数据传递需要结组操作系统提供特殊的方法,如:文件、管道、信号、共享内存、消息队列、套接字、命名管道等
一些方法由于自身设计缺陷被淘汰或者弃用。现今常用的进程间通信为:

1.管道(使用最简单)
2.信号(开销最小)
3.共享映射区(无血缘关系进程之间)
4.本地套接字(最稳定)


默认提到的管道是匿名管道,只能用在有血缘关系的进程之间。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值