进程通信之共享内存

       共享内存:申请一块内存(4KB的整数倍,非整数倍,向上取整),使得对个进程可以访问同一块内存空间,是最快的IPC形式(无需将数据进行拷贝,移动数据),共享内存方式不具备同步与互斥机制,通常与其它通信机制结合,达到进程间的同步与互斥,共享内存方式的ipc资源的生命周期为“随内核”,需用户显式删除。

   通常使用:
   ipcs -m          查看共享内存

   ipcrm -m shmid   删除共享内存

   共享内存方式的进程间通信操作如下:

程序代码:

comm.h

进程通信之共享内存

comm.c

进程通信之共享内存

server.c  client.c

进程通信之共享内存

测试:

进程通信之共享内存

    共享内存既有优点也有缺点,其优点在于它是进程通信四种方式中最快的,因为它无需多次拷贝数据,移动数据;其次,共享内存中ipc资源的生命周期是“随内核”,需用户显式删除;共享内存需先被创建,再被映射到两个进程的逻辑地址中。

    缺点在于共享内存本身不自带同步与互斥机制,若要使其实现同步与互斥机制,需与其它通信方式配合使用,如与信号量配合使用,信号量中的P,V操作为原子操作。