[转] 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多进程拷贝大文件.
  • Thus_
  • Thus_
  • 2017年10月21日 17:45
  • 64

Linux的mmap内存映射机制解析

在讲述文件映射的概念时, 不可避免的要牵涉到虚存(SVR 4的VM). 实际上, 文件映射是虚存的中心概念, 文件映射一方面给用户提供了一组措施, 好似用户将文件映射到自己地址空间的某个部分, 使用...

深入剖析Android音频之AudioTrack

播放声音可以用MediaPlayer和AudioTrack,两者都提供了java API供应用开发者使用。虽然都可以播放声音,但两者还是有很大的区别的。其中最大的区别是MediaPlayer可以播放多...

Linux进程间通信(IPC)编程实践(六)共享内存的使用-mmap

共享内存区是最快的IPC形式。一旦这样的内存映射到共享它的进程的地址空间,这些进程间数据传递不再涉及到内核,换句话说是进程不再通过执行进入内核的系统调用来传递彼此的数据(如图)。 共享内存和其他进...
  • NK_test
  • NK_test
  • 2015年11月21日 14:46
  • 2193

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

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

Linux下通过共享内存进行进程间通信,进程间同步使用信号量来实现

Linux 环境下C编程指南,通过共享内存进行进程间通信的例子,进程间同步使用信号量来实现。、 书中有几个错误。。 使用说明:这是一个简单的服务器和客户端程序,如果启动程序时不带参数,则执...

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

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

Linux环境进程间通信(五): 共享内存(上) mmap [Important !!!!!!!!!]

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

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

二、mmap()及其相关系统调用 mmap()系统调用使得进程之间通过映射同一个普通文件实现共享内存。普通文件被映射到进程地址空间后,进程可以向访问普通内存一样对文件进行访问,不必再调用read...
  • zhubosa
  • zhubosa
  • 2016年07月19日 12:27
  • 242

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

内核怎样保证各个进程寻址到同一个共享内存区域的内存页面 1、page cache及swap cache中页面的区分:一个被访问文件的物理页面都驻留在page cache或swap cache中,一个页...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:[转] linux下使用mmap实现进程间共享内存
举报原因:
原因补充:

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