进程通信之共享内存
共享内存:申请一块内存(4KB的整数倍,非整数倍,向上取整),使得对个进程可以访问同一块内存空间,是最快的IPC形式(无需将数据进行拷贝,移动数据),共享内存方式不具备同步与互斥机制,通常与其它通信机制结合,达到进程间的同步与互斥,共享内存方式的ipc资源的生命周期为“随内核”,需用户显式删除。
通常使用:
ipcs -m 查看共享内存
ipcrm -m shmid 删除共享内存
共享内存方式的进程间通信操作如下:
程序代码:
comm.h
comm.c
server.c client.c
测试:
共享内存既有优点也有缺点,其优点在于它是进程通信四种方式中最快的,因为它无需多次拷贝数据,移动数据;其次,共享内存中ipc资源的生命周期是“随内核”,需用户显式删除;共享内存需先被创建,再被映射到两个进程的逻辑地址中。
缺点在于共享内存本身不自带同步与互斥机制,若要使其实现同步与互斥机制,需与其它通信方式配合使用,如与信号量配合使用,信号量中的P,V操作为原子操作。