[转] linux下使用mmap实现进程间共享内存

转载 2015年11月19日 21:51:59

转自:http://www.rigongyizu.com/linux-threads-mmap-share-memory/

Linux下的mmap函数是把文件内容映射到一块内存(准确的说是虚拟内存)上,可以把对文件的操作转为对内存的操作,从而可以避免很多lseek()与read()、write()操作,非常适合于操作大文件或者频繁访问的文件。mmap一般的用途有:

1.将某个真实的文件读入内存,可以频繁读写,在必要的时候写回磁盘

2.各进程间可以共享映射区域

#include <sys/mman.h>
#include <sys/types.h>
#include <fcntl.h>
#include <unistd.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>

typedef struct {
    char name[10];
    int age;
} person;

int main(){
    int i;
    person *p_map;
    int size;
    size = 10*sizeof(person);
    p_map=(person*)mmap(NULL, size, PROT_READ|PROT_WRITE, MAP_SHARED|MAP_ANONYMOUS, -1, 0);

    if(fork() == 0){

        sleep(2);

        for(i=0;i<10;i++){
            printf("child read: the %d person %s's age is %dn", i+1,(*(p_map+i)).name , (*(p_map+i)).age);
        }
        (*p_map).age = 100;
        munmap(p_map, size);
        return 0;
    }

    for(i=0;i<10;i++){
        sprintf( (*(p_map+i)).name, "name%d", i);
        (*(p_map+i)).age=20+i;
    }

    sleep(5);

    printf("parent read: the first person's age is %dn", (*p_map).age);
    munmap(p_map, size);

    return 0;
}

总结:

1 举一个典型的应用场景:如在显示LCD汉字时,通常会把字库文件,映射到内存空间中,大而且频繁使用。另外需要将一个文件内容分页显示在LCD上,也可以将待显示文件映射至内存空间中。

2 关于其作为进程之间通信方法的深入探讨,会有专门一个专题进行阐述。

 


关于mmap内存映射的修改同步

以前使用过mmap函数,但是没有分析过,只是使用而已。 在看到《APUE》中第十四章的mmap内存映射才发现,当时自己是侥幸使用而已,没有遇到什么问题。 主要是没有考虑映射后的内存空间修改后,被映...
  • tietao
  • tietao
  • 2012年03月28日 22:06
  • 3794

多进程和mmap 实现copy的demo

#include #include #include #include #include #include #include #include #include #define MAX_LEN 10...
  • Isehers
  • Isehers
  • 2015年02月07日 22:46
  • 202

mmap函数用法及示例程序

UNIX网络编程第二卷进程间通信对mmap函数进行了说明。该函数主要用途有三个: 1、将一个普通文件映射到内存中,通常在需要对文件进行频繁读写时使用,这样用内存读写取代I/O读写,以获得较高的性能;...
  • xiaohuima_dong
  • xiaohuima_dong
  • 2015年03月26日 22:38
  • 2517

Linux进程间通信--mmap共享内存(一)

共享内存可以说是最有用的进程间通信方式,也是最快的IPC形式。两个不同进程A、B共享内存的意思是,同一块物理内存被映射到进程A、B各自的进程地址空间。进程A可以即时看到进程B对共享内存中数据的更新,反...
  • yusiguyuan
  • yusiguyuan
  • 2015年04月20日 20:03
  • 2708

linux-使用互斥锁完成多进程同步

#include #include #include #include #include #include #include...
  • G_BrightBoy
  • G_BrightBoy
  • 2011年10月12日 13:08
  • 10935

Linux下的多进程间共享资源的互斥访问

把源代码运行一遍就知道了#include #include #include #include #include #include pthread_mutex_t*...
  • lanseshenhua
  • lanseshenhua
  • 2010年05月04日 19:21
  • 7960

linux下多进程共享资源互斥访问实例

#include       #include       #include       #include       #include       #include       pthr...
  • u011402017
  • u011402017
  • 2016年12月22日 17:31
  • 558

mmap的使用之两个进程通过映射普通文件实现共享内存通信

/*-------------map_normalfile1.c-----------*/ #include #include #include #include #include #inc...
  • earbao
  • earbao
  • 2016年05月30日 10:13
  • 987

linux 中mmap的用法(进程间通信-共享内存)

转自 : http://blog.csdn.net/angelbosj/article/details/8272887 函数:void *mmap(void *start,size_t le...
  • xiaoxianerqq
  • xiaoxianerqq
  • 2016年11月15日 09:34
  • 1115

细说linux IPC(三):mmap系统调用共享内存

【版权声明:尊重原创,转载请保留出处:blog.csdn.net/shallnet 或 .../gentleliu,文章仅供学习交流,请勿用于商业用途】         前面讲到socket的进程间通...
  • gentleliu
  • gentleliu
  • 2014年11月11日 08:53
  • 2107
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:[转] linux下使用mmap实现进程间共享内存
举报原因:
原因补充:

(最多只允许输入30个字)