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

Linux系统编程 80 进程间的通信方式,第1张

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

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


进程间通信的原理:

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

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

图1

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

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


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

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5704189.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-17
下一篇 2022-12-17

发表评论

登录后才能评论

评论列表(0条)

保存