当前位置:   article > 正文

进程间通信---共享内存_进程间共享内存段通信

进程间共享内存段通信

       前边说过,进程间通信的实质就是让两个不相干的进程看到同一份公共的资源,而内存是资源的一种,那么,如果让两个进程可以使用同一块内存,两个进程都可以往这块内存里边写东西和取东西,这不就是实现了进程间的通信了么。通过共享内存实现进程间的通信,原理很简单,主要就是它的实现了。

       每个进程都具有自己独立的地址空间,又怎么让两个进程共享同一块内存呢?我们都知道,给进程的地址空间其实都是虚拟地址,然后操作系统会根据进程的实际需要才给进程分配合适的物理内存(将虚拟地址映射到物理地址空间中去),那么问题就好解决了,只要两个进程映射到同一块物理内存空间不就行了?但是映射的过程是由操作系统完成与控制,怎么让属于不同进程的两块虚拟地址空间映射到同一块内存空间呢?


系统提供了几个函数来帮助我们实现以上过程。掌握了这几个函数,也就相当于掌握了共享内存。

shmget函数  ---创建

功能:用于创建共享内存
原型:int  shmget(key_t key,size_t size,int shmflg)
参数:key:这个共享内存段的名字
  size:共享内存的大小
  shmflg:由九个权限标志构成,其用法跟创建文件时使用的mode模式标志一样。

返回值:成功返回一个非负整数,即该共享内存段的标志码;失败返回-1

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/正经夜光杯/article/detail/1000834
推荐阅读
相关标签
  

闽ICP备14008679号