共享内存
来源:互联网 发布:故宫淘宝官方旗舰店 编辑:程序博客网 时间:2024/05/22 01:37
原理
- Linux不同的进程所占用的虚拟内存通过页表映射到不同物理内存,通过专门的函数可以使不同的进程访问到同一块物理内存,这样不同的进程就可以通过直接在这块物理内存中读写数据实现通信。
- 相比于管道通信,共享内存省去了两次拷贝过程,速度更快。
管道通信: 数据从进程一所占用的内存拷贝到管道,再从管道拷贝到进程二,实现通信。
函数接口
#include <sys/types.h>#include <sys/shm.h>int shmget(key_t key, size_t size, int shmflg);//创建共享内存void* shmat(int shmid, const void* shmaddr, int shmflg);//获取共享内存地址(与自己的页表建立映射关系)int shmdt(const void* shmaddr);//解除映射int shmctl(int shmid, int cmd, struct shmid_ds* buf);//控制共享内存
阅读全文
0 0
- 【共享内存】共享内存
- 共享内存
- 共享内存
- 共享内存
- 共享内存
- 共享内存
- 共享内存
- 共享内存
- 共享内存
- 共享内存
- 共享内存
- 共享内存
- 共享内存
- 共享内存
- 共享内存
- 共享内存
- 共享内存
- 共享内存
- Java Killer系列之Java经典面试套路讲解
- 简单哈夫曼 编/译码系统的设计与实现
- 阿里云服务器centos6.8 的安装及配置java web环境
- http通信过程中,Web浏览器与Web服务器之间将完成下列7个步骤
- [leetcode]: 338. Counting Bits
- 共享内存
- CSS入门
- CSS揭秘读书笔记-第一章 引言
- stm32视频教程分享:心率检测仪的设计与实现
- C# List集合的安全操作方式
- 3. 后期工作(组长) 3.1 后期组长的工作分为三部分 3.1.1 审查合并 3.1.2 发布项目和版本变更 3.1.3 Gitlab加标签(项目上线以后)
- 使用分层实现业务处理
- Failure to transfer org.apache.maven.plugins:maven-war-plugin:pom:xxx
- Activity创建过程