1. 共享内存的定义
共享内存指(shared memory)在多处理器的计算机系统中,可以被不同中央处理器(CPU)访问的大量内存。由于多个CPU需要快速访问存储器,这样就要对存储器进行缓存(Cache)。
共享内存就是允许多个不相关的进程访问同一个逻辑内存
- 共享内存是在两个正在运行的进程之间共享和传递数据的一种非常有效的方式;
- 不同进程之间共享的内存通常安排为同一段物理内存;
- 进程可以将同一段共享内存连接到它们自己的地址空间中,所有进程都可以访问共享内存中的地址;
- 如果某个进程向共享内存写入数据,所做的改动立即影响到可以访问同一段共享内存的任何其它进程;
共享内存没有提供同步机制,也就是说,在第一个进程对共享内存写操作结束之前,并无自动可以阻止第二个进程开始对其进行读取。所以要使用信号量来进行同步控制。
2. 共享内存的特点
1. 最快的IPC,高效率
通过管道方式来进行进程间通信
- 从内存空间缓冲区将数据拷贝到内核空间缓冲区;
- 从内核空间缓冲区将数据拷贝到内存;
- 从内存将数据拷贝到内核空间缓冲区;
- 从内核空间缓冲区将数据拷贝到用户空间缓冲区;
通过共享内存进行进