1mmap()依赖的头文件

#include

2函数声明:

void *mmap(void *addr, size_t length, intprot, int flags,

intfd, off_t offset);

int munmap(void *addr, size_t length);

函数说明:

mmap可以把磁盘文件的一部分直接映射到内存,这样文件中的位置直接就有对应的内存

地址,对文件的读写可以直接用指针来做而不需要read/write函数。

3.内存映射图:

说明:

如果addr参数为NULL,内核会自己在进程地址空间中选择合适的地址建立映射。如果

addr不是NULL,则给内核一个提示,应该从什么地址开始映射,内核会选择addr之上的某个合适的地址开始映射。建立映射后,真正的映射首地址通过返回值可以得到。len参数是需要映射的那一部分文件的长度。off参数是从文件的什么位置开始映射,必须是页大小的整数倍(在32位体系统结构上通常是4K)。filedes是代表该文件的描述符。

prot参数有四种取值:

* PROT_EXEC表示映射的这一段可执行,例如映射共享库

* PROT_READ表示映射的这一段可读

* PROT_WRITE表示映射的这一段可写

* PROT_NONE表示映射的这一段不可访问

flag参数有很多种取值,这里只讲两种,其它取值可查看mmap(2)

* MAP_SHARED多个进程对同一个文件的映射是共享的,一个进程对映射的内存做了修

改,另一个进程也会看到这种变化。

* MAP_PRIVATE多个进程对同一个文件的映射不是共享的,一个进程对映射的内存做了修改,另一个进程并不会看到这种变化,也不会真的写到文件中去。

如果mmap成功则返回映射首地址,如果出错则返回常数MAP_FAILED。当进程终止时,该进程的映射内存会自动解除,也可以调用munmap解除映射。munmap成功返回0,出错返回-1。

下面做一个简单的实验

helloworld

[email protected]:~$ od -tx1 -tc hello

0000000 68 65 6c 6c 6f 77 6f 72 6c 64 0a

h

e l l o wo

r l d \n

0000013

使用mmap映射

#include

#include

#include

int main(void)

{

int *p;

int fd = open("hello", O_RDWR);

if (fd < 0) {

perror("open hello");

exit(1);

}

p = mmap(NULL, 6, PROT_WRITE, MAP_SHARED, fd, 0);

if (p == MAP_FAILED) {

perror("mmap");

exit(1);

}

close(fd);

p[0] = 0x30313233;

munmap(p, 6);

return 0;

}

案例2

写端案例(注意要传递进去一个已经存在的文件名):

#include

#include

#include

#include

#include

#include

#include

#define MAPLEN 0x1000

void sys_err(char *str,int exitno)

{

perror(str);

exit(exitno);

}

int main(int argc,char *argv[])

{

char *mm;

int fd,i = 0;

if(argc < 2)

{

printf("./a.out filename\n");

exit(1);

}

fd = open(argv[1],O_RDWR|O_CREAT,0777);

if(fd < 0)

{

sys_err("open",1);

}

if(lseek(fd,MAPLEN-1,SEEK_SET) < 0)

{

sys_err("lseek",3);

}

if(write(fd,"\0",1) < 0)

{

sys_err("write",4);

}

//使用MAP_SHARED共享的方式,也就是说:内存或磁盘文件中的一者发生内容变化

mm = mmap(NULL,MAPLEN,PROT_READ|PROT_WRITE,MAP_SHARED,fd,0);

if(mm == MAP_FAILED){

sys_err("mmap",2);

}

close(fd);

while(1)

{

sprintf(mm,"hello%d",i++);

sleep(1);

}

munmap(mm,MAPLEN);

return 0;

}

读端的案例:

#include

#include

#include

#include

#include

#include

#include

#define MAPLEN 0x1000

void sys_err(char *str,int exitno)

{

perror(str);

exit(exitno);

}

int main(int argc,char *argv[])

{

char *mm;

int fd,i = 0;

if(argc < 2)

{

printf("./a.out filname\n");

exit(1);

}

fd = open(argv[1],O_RDWR);

if(fd < 0)

{

sys_err("open",1);

}

mm = mmap(NULL,MAPLEN,PROT_READ|PROT_WRITE,MAP_SHARED,fd,0);

if(mm == MAP_FAILED)

{

sys_err("mmap",2);

}

close(fd);

while(1)

{

printf("%s\n",mm);

sleep(1);

}

munmap(mm,MAPLEN);

return 0;

}

原文:http://blog.csdn.net/tototuzuoquan/article/details/39437885

实验3 linux内存映射,3Linux内存映射,mmap()函数相关推荐

  1. Linux系统编程---5(共享存储映射,存储映射I/O,mmap函数,父子进程间通信,匿名映射)

    共享存储映射 文件进程间通信 使用文件也可以完成 IPC,理论依据是,fork 后,父子进程共享文件描述符.也就共享打开的文件. 编程:父子进程共享打开的文件.借助文件进行进程间通信. 测试代码 /* ...

  2. 【操作系统实验】Linux进程通信—共享内存通信、管道通信

    Linux进程通信-共享内存通信.管道通信 一.实验目的: 二.实验题目: 1. 试设计程序利用共享内存完成如下进程通信 1.shmget函数 2.shmat函数 3.shmdt函数 4.shmctl ...

  3. linux驱动静态分配内存,Linux驱动设计——内存与IO访问

    名词解释 内存空间与IO空间 内存空间是计算机系统里面非系统内存区域的地址空间,现在的通用X86体系提供32位地址,寻址4G字节的内存空间,但一般的计算机只安装256M字节或者更少的内存,剩下的高位内 ...

  4. 什么是共享内存?在内存中的具体位置?shmget的具体使用原理以及其他关联函数(shmat ( ),shmdt ( ),shmctl ( ))、以及C++应用案例?mmap和shm的区别?

    共享内存(shared memory) 共享内存 1.背景 2.定义 3.两种方式(mmap上一篇博客说明) 3.2.shmget 3.2.1.使用流程和基本原理 3.2.2.函数原型(创建共享内存) ...

  5. Linux内存映射--mmap函数

    Linux提供了内存映射函数mmap, 它把文件内容映射到一段内存上(准确说是虚拟内存上), 通过对这段内存的读取和修改, 实现对文件的读取和修改, 先来看一下mmap的函数声明: 头文件: < ...

  6. 3Linux内存映射,mmap()函数

     1mmap()依赖的头文件 #include <sys/mman.h> 2函数声明: void *mmap(void *addr, size_t length, intprot, i ...

  7. linux usb ga驱动详解,Linux设备驱动之内存映射

    1. 内存映射 所谓的内存映射就是把物理内存映射到进程的地址空间之内,这些应用程序就可以直接使用输入输出的地址空间,从而提高读写的效率.Linux提供了mmap()函数,用来映射物理内存. 在驱动程序 ...

  8. Linux内存管理:反向映射机制(匿名页,文件页和ksm页)

    目录 1.反向映射的发展 2.反向映射应用场景 3.匿名页的反向映射 4.文件页的反向映射 5.ksm页的反向映射 6.总结 7.作者简介 8.推荐阅读 为了系统的安全性,Linux内核将各个用户进程 ...

  9. 【Linux 内核 内存管理】内存映射相关数据结构 ③ ( vm_area_struct 结构体成员分析 | shared 成员 | anon_vma_chain 成员 | anon_vma 成员 )

    文章目录 一.vm_area_struct 结构体成员分析 1.shared 成员 2.anon_vma_chain 成员 3.anon_vma 成员 二.vm_area_struct 结构体完整源码 ...

最新文章

  1. 用C#编写获取远程IP,MAC的方法
  2. oracle不维护java_宣布 Java 8 停止维护后,Oracle 又毙掉了 JavaOne!
  3. Git本地与远程配对命令:两种 一种是在推送push时候配对 一种是新建分支checkout -b时候配对
  4. 【网络设计_RegNet】Designing Network Design Spaces_2020
  5. jsonp跨域原理_Rust 搭建可跨域访问服务器JsonP(一)
  6. ZooKeeper程序员指南--使用ZooKeeper开发分布式应用程序
  7. 【Vue2.0】— 组件的自定义事件(十八)
  8. 如何在三层交换机上实现跨VLAN 的DHCP配置
  9. oracle-审计3
  10. XGBoost数据训练小例子
  11. rm mysql 数据日志文件恢复
  12. 谷歌浏览器安装json-handle插件
  13. 2023年西北工业大学材料科学与工程考研考情与难度、参考书及上岸前辈初复试备考经验指导
  14. 台达触摸屏和vfd-m变频器通讯控制监视程序 使用modbus rtu通讯方式,在触摸屏可以直接控制变频器
  15. 小程序容器在一体化在线政务服务平台中的应用
  16. 第三部分 数据结构 -- 第四章 图论算法1374:铲雪车(snow)
  17. IELTS-writing exercise Expository_Text_18
  18. 自动预测保险理赔:机器学习之特征预处理(Kaggle保险索赔竞赛案例)
  19. 春林文件批量改名系统
  20. 用flex布局实现携程网首页的制作

热门文章

  1. MySQL下mysql.sock丢失问题的解决[ubuntu, linux, mysqld.sock]
  2. 解决Jira和Confluence访问打开越来越缓慢问题
  3. Docker中的“公开”和“发布”有什么区别?
  4. Python错误“ ImportError:未命名模块”
  5. PXC DDL 操作阻塞写
  6. css中em单位详解,说明
  7. 深度学习训练,选择P100就对了
  8. C#将DataTable转换成list的方法
  9. Struts 2 --ONGL介绍
  10. 设计模式 之 设计的 六大原则(1)单一职责原则