栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 系统运维 > 运维 > Linux

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

Linux 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

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

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


进程间通信的原理:

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

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

图1

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

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


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

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/705626.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号