1.共享内存指在多处理器的计算机系统中,可以被不同中央处理器访问的大容量内存。由于多个CPU需要快速访问存储器,这样就要对存储器进行缓存。由于其他处理器可能也要存取,任一缓存数据更新后,共享内存就需要立即更新,否则不同处理器可能用到不同的数据
优点:内存共享是最为高效的IPC机制,因为它不涉及到进程之间的任何的数据传输;
缺点:需要其他辅助手段来同步进程对共享内存的访问,否则会产生竞争条件;因为共享内存本身没有提供同步机制,所以通常使用信号量来实现对共享内存访问的同步。
内存共享原理图:
2.linux中的共享内存的实现主要包括4个系统调用,分别是:
(1) int shmget(key_t key, size_t size, int shmflg);
(2) void *shm