共享内存概念

共享内存是通信效率最高的IPC形式,因为过程能够间接读写内存,而无需进行数据的拷备。然而它没有自带同步机制,须要配合信号量等形式来进行同步。

共享内存被创立当前,同一块物理内存被映射到了多个过程地址空间,当有一个过程批改了共享内存的数据,其余的过程均可看见所批改的内容,反之亦然。

mmap函数

函数原型:

void mmap(void adrr, size_t length, int prot, int flags, int fd, off_t offset);

返回值:

胜利:返回创立的映射区首地址;

失败:返回MAP_FAILED

具体参数含意:

addr:指向映射区的首地址,这是由零碎内核所决定的,个别设为NULL;

length:欲创立的映射区大小;

prot:映射区的权限,个别有如下几种:

PROT_EXEC 映射区域可被执行

PROT_READ 映射区域可被读取

PROT_WRITE 映射区域可被写入

PROT_NONE 映射区域不能存取

flags:指映射区的标记位,MAP_FIXED与MAP_PRIVATE必须抉择一个:

MAP_FIXED:对映射区所作的批改会反映到物理设施,但须要调用msync()或者munmap();

MAP_PRIVATE:对映射区所作的批改不会反映到物理设施。

fd:创立的映射区的文件描述符;

offset:被映射文件的偏移量,个别设为0,示意从头开始映射。

mumap函数

函数原型:

int munmap(void *addr, size_t length);

函数作用:

如同malloc之后须要free一样,mmap调用创立的映射区应用结束之后,须要调用munmap去开释。

例程

写过程:

 1#include <stdio.h> 2#include <sys/mman.h> 3#include <sys/types.h> 4#include <sys/stat.h> 5#include <fcntl.h> 6#include <unistd.h> 7#include <string.h> 8 9typedef struct10{11    int id;12    char name[20];13    char gender;14}stu;1516int main(int argc, char *argv[])17{18    stu *p = NULL;19    int fd = 0;20    stu student = {10, "harry", 'm'};2122    if (argc < 2) {23        printf("useage: ./a.out file\n");24        return -1;25    }2627    fd = open(argv[1], O_RDWR | O_CREAT, 0664);28    if (fd == -1) {29        printf("ERROR: open failed!\n");30        return -1;31    }32    ftruncate(fd, sizeof(stu));3334    p = mmap(NULL, sizeof(stu), PROT_READ | PROT_WRITE, MAP_SHARED, fd, 0);35    if (p == MAP_FAILED) {36        printf("ERROR: mmap failed!\n");37        return -1;38    }3940    close(fd);4142    while (1) {43        memcpy(p, &student, sizeof(stu));44        student.id++;45        sleep(2);46    }47    munmap(p, sizeof(stu));4849    return 0;50}

读过程:

 1#include <stdio.h> 2#include <sys/mman.h> 3#include <sys/types.h> 4#include <sys/stat.h> 5#include <fcntl.h> 6#include <unistd.h> 7 8typedef struct 9{10    int id;11    char name[20];12    char gender;13}stu;1415int main(int argc, char *argv[])16{17    stu *p = NULL;18    int fd = 0;1920    if (argc < 2) {21        printf("useage: ./a.out file\n");22        return -1;23    }2425    fd = open(argv[1], O_RDONLY);26    if (fd == -1) {27        printf("ERROR: open failed!\n");28        return -1;29    }3031    p = mmap(NULL, sizeof(stu), PROT_READ, MAP_SHARED, fd, 0);32    if (p == MAP_FAILED) {33        printf("ERROR: mmap failed!\n");34        return -1;35    }3637    close(fd);3839    while (1) {40        printf("id = %d, name = %s, gender = %c\n", p->id, p->name, p->gender);41        sleep(2);42    }4344    munmap(p, sizeof(stu));4546    return 0;47}

更多精彩内容,请关注公众号良许Linux,公众内回复1024可收费取得5T技术材料,包含:Linux,C/C++,Python,树莓派,嵌入式,Java,人工智能,等等。公众号内回复进群,邀请您进高手如云技术交换群。


最初,最近很多小伙伴找我要Linux学习路线图,于是我依据本人的教训,利用业余时间熬夜肝了一个月,整顿了一份电子书。无论你是面试还是自我晋升,置信都会对你有帮忙!

收费送给大家,只求大家金指给我点个赞!

电子书 | Linux开发学习路线图

也心愿有小伙伴能退出我,把这份电子书做得更完满!

有播种?心愿老铁们来个三连击,给更多的人看到这篇文章

举荐浏览:

  • 干货 | 程序员进阶架构师必备资源免费送
  • 神器 | 反对搜寻的资源网站