system v 共享内存
每个进程都是独立的,当进程运行起来时,都有一个PCB,一个虚拟地址空间,一个页表,一个对应的物理内存,页表将每一个进程的PCB映射到物理内存的不同区域,保证了它们的独立性。但是如果两个页表都分别把进程虚拟地址空间的一些内容映射到物理内存的同一块区域,那么这样就实现了两个进程看到同一份资源了,而这一块公共的区域就叫做共享内存!如图所示:
因为可以减少进程间数据拷贝的次数,所以共享内存区是速度最快的IPC形式。一旦这样的内存映射到共享它的进程的地址空间,这些进程间数据传递不再涉及到内核,换句话说是进程不再通过执行进入内核的系统调用来传递彼此的数据。
但与此同时,共享内存是直接暴露给用户的,所以没办法进行保护,则意味着不提供任何的互斥与同步机制,必须由用户自己来提供。因为它是system v 版本的IPC资源,所以生命周期随内核,也就是说你进程退出时,并不会删掉这一块共享内存。
共享内存的控制-----创建、挂接,脱离、删除
对于共享内存,我们能做的无非就只有四个动作,创建、挂接、脱离、删除。其中前两个可归类为创建,后两个归类为删除。那么具体的实现是要用到下面四个函数: