学习笔记
在linux环境下,进程地址空间相互独立的,每个进程各自有不同的用户地址空间。
任何一个进程的全局变量在另一个进程中都看不到,所以进程和进程之间不能相互访问。
要交换数据,必须通过内核,在内核中开辟一块缓冲区,进程1把数据从用户空间拷贝到
内核缓冲区,进程2再从内核缓冲区把数据拷贝走,内核提供的这种机制称为进程间的通信。
IPC(interprocesscommunication).
进程地址空间是独立的。
父进程和子进程之间搭建桥梁。
这个桥梁就是进程间通信IPC
进程间通信的原理:
0g-3g:是用户空间
3g-4g:是内核空间
*** 作系统的内核空间是共享的。所以进程之间有相同的内核空间。
桥梁的本质:内核空间中的一块缓冲区。
图1
在进程间完成数据传递需要结组 *** 作系统提供特殊的方法,如:文件、管道、信号、共享内存、消息队列、套接字、命名管道等
一些方法由于自身设计缺陷被淘汰或者弃用。现今常用的进程间通信为:
1.管道(使用最简单)
2.信号(开销最小)
3.共享映射区(无血缘关系进程之间)
4.本地套接字(最稳定)
默认提到的管道是匿名管道,只能用在有血缘关系的进程之间。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)