赞
踩
前边说过,进程间通信的实质就是让两个不相干的进程看到同一份公共的资源,而内存是资源的一种,那么,如果让两个进程可以使用同一块内存,两个进程都可以往这块内存里边写东西和取东西,这不就是实现了进程间的通信了么。通过共享内存实现进程间的通信,原理很简单,主要就是它的实现了。
每个进程都具有自己独立的地址空间,又怎么让两个进程共享同一块内存呢?我们都知道,给进程的地址空间其实都是虚拟地址,然后操作系统会根据进程的实际需要才给进程分配合适的物理内存(将虚拟地址映射到物理地址空间中去),那么问题就好解决了,只要两个进程映射到同一块物理内存空间不就行了?但是映射的过程是由操作系统完成与控制,怎么让属于不同进程的两块虚拟地址空间映射到同一块内存空间呢?
系统提供了几个函数来帮助我们实现以上过程。掌握了这几个函数,也就相当于掌握了共享内存。
shmget函数 ---创建
功能:用于创建共享内存
原型:int shmget(key_t key,size_t size,int shmflg)
参数:key:这个共享内存段的名字
size:共享内存的大小
shmflg:由九个权限标志构成,其用法跟创建文件时使用的mode模式标志一样。
返回值:成功返回一个非负整数,即该共享内存段的标志码;失败返回-1
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。