0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

共享内存IPC原理,Linux进程间如何共享内存?

马哥Linux运维 来源:未知 作者:李倩 2018-07-16 13:43 次阅读

共享内存是在内存中单独开辟的一段内存空间,这段内存空间有自己特有的数据结构,包括访问权限、大小和最近访问的时间等。

共享内存 IPC 原理

共享内存进程间通信机制主要用于实现进程间大量的数据传输,下图所示为进程间使用共享内存实现大量数据传输的示意图:

共享内存是在内存中单独开辟的一段内存空间,这段内存空间有自己特有的数据结构,包括访问权限、大小和最近访问的时间等。该数据结构定义如下:

from /usr/include/linux/shm.hstruct shmid_ds {struct ipc_perm shm_perm; /* operation perms 操作权限 */int shm_segsz; /* size of segment (bytes) 段长度大小 */__kernel_time_t shm_atime; /* last attach time 最近attach时间 */__kernel_time_t shm_dtime; /* last detach time 最近detach时间 */__kernel_time_t shm_ctime; /* last change time 最近change时间 */__kernel_ipc_pid_t shm_cpid; /* pid of creator 创建者pid */__kernel_ipc_pid_t shm_lpid; /* pid of last operator 最近操作pid */unsigned short shm_nattch; /* no. of current attaches */unsigned short shm_unused; /* compatibility */void *shm_unused2; /* ditto - used by DIPC */void *shm_unused3; /* unused */|};

两个进程在使用此共享内存空间之前,需要在进程地址空间与共享内存空间之间建立联系,即将共享内存空间挂载到进程中。

系统对共享内存做了以下限制:

#define SHMMAX 0x2000000 /* max shared seg size (bytes) 最大共享段大小 */#define SHMMIN 1 /* min shared seg size (bytes) 最小共享段大小 */#define SHMMNI 4096 /* max num of segs system wide */#define SHMALL (SHMMAX/getpagesize()*(SHMMNI/16))|define SHMSEG SHMMNI /* max shared segs per process */Linux 共享内存管理

1.创建共享内存

#include #include

/** 第一个参数为 key 值,一般由 ftok() 函数产生* 第二个参数为欲创建的共享内存段大小(单位为字节)* 第三个参数用来标识共享内存段的创建标识*/

int shmget(key_t key, size_t size, int shmflg);

2.共享内存控制

#include #include

/** 第一个参数为要操作的共享内存标识符* 第二个参数为要执行的操作* 第三个参数为 shmid_ds 结构的临时共享内存变量信息*/

int shmctl(int shmid, int cmd, struct shmid_ds *buf);

3.映射共享内存对象

系统调用 shmat() 函数实现将一个共享内存段映射到调用进程的数据段中,并返回内存空间首地址,其函数声明如下:

#include #include

/** 第一个参数为要操作的共享内存标识符* 第二个参数用来指定共享内存的映射地址,非0则为此参数,为0的话由系统分配* 第三个参数用来指定共享内存段的访问权限和映射条件*/

void *shmat(int shmid, const void *shmaddr, int shmflg);

4.分离共享内存对象

在使用完毕共享内存空间后,需要使用 shmdt() 函数调用将其与当前进程分离。函数声明如下:

#include #include

/** 参数为分配的共享内存首地址*/

int shmdt(const void *shmaddr);共享内存在父子进程间遵循的约定

1.使用 fork() 函数创建一个子进程后,该进程继承父亲进程挂载的共享内存。

2.如果调用 exec() 执行一个新的程序,则所有挂载的共享内存将被自动卸载。

3.如果在某个进程中调用了 exit() 函数,所有挂载的共享内存将与当前进程脱离关系。

程序实例

申请一段共享内存,父进程在首地址处存入一整数,子进程读出。

#include#include #include #include #include#include#define SHM_SIZE 1024int main(){int shm_id, pid;int *ptr = NULL;

/* 申请共享内存 */

shm_id = shmget((key_t)1004, SHM_SIZE, IPC_CREAT | 0600);

/* 映射共享内存到进程地址空间 */

ptr = (int*)shmat(shm_id, 0, 0);printf("Attach addr is %p ", ptr);*ptr = 1004;printf("The Value of Parent is : %d ", *ptr);if((pid=fork()) == -1){perror("fork Err");exit(0);}else if(!pid){printf("The Value of Child is : %d ", *ptr);exit(0);}else{sleep(1);

/* 解除映射 */

shmdt(ptr);

/* 删除共享内存 */

shmctl(shm_id, IPC_RMID, 0);}return 0;}

输出结果:

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • Linux
    +关注

    关注

    87

    文章

    11292

    浏览量

    209323
  • 共享内存
    +关注

    关注

    0

    文章

    16

    浏览量

    8313

原文标题:架构师进阶:Linux进程间如何共享内存?

文章出处:【微信号:magedu-Linux,微信公众号:马哥Linux运维】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    Linux进程如何实现共享内存通信

    这次我们来讲一下Linux进程通信中重要的通信方式:共享内存作为Linux软件开发攻城狮,进程
    发表于 04-26 17:14 692次阅读

    使用Rust语言的WinAPI模块来实现共享内存

    进程通信(IPC)是操作系统中非常重要的一部分,它使得不同的进程可以在不同的计算机上进行通信。在Windows操作系统中,共享
    的头像 发表于 09-19 16:15 2007次阅读

    关于共享内存的函数shmget()

    Linux进程通信源码剖析,共享内存(shmget函数详解)标签: linuxstruct数据结构存储systemobject2010-
    发表于 09-24 15:47

    关于内存共享的shmget()函数的解析

    Linux进程通信源码剖析,共享内存(shmget函数详解)标签: linuxstruct数据结构存储systemobject2010-
    发表于 09-24 15:49

    Linux进程通信——使用共享内存

    Linux进程通信——使用共享内存 图文详情见附件
    发表于 11-21 10:53

    请问IPC安装完后的共享内存是谁给划定的?,LINUX和SYS/BISO的messageQ是怎样实现共享内存的同步的?

    一直没看懂,IPC安装完后的共享内存是谁给划定的,LINUX和SYS/BISO的messageQ是怎样实现共享
    发表于 07-24 08:51

    linux如何共享内存实验

    ;  struct shm_buff *shm_buff_inst;  char buffer[BUFSIZ];  int shmid, semid;  /* 定义信号量,用于实现访问共享内存进程
    发表于 06-08 07:47

    Linux现有的所有进程IPC方式

    在开始回答前,先简单概括性地说说Linux现有的所有进程IPC方式:1. **管道:**在创建时分配一个page大小的内存,缓存区大小比较
    发表于 08-20 06:17

    进程通信之共享内存

    8.5.1 共享内存概述 可以说,共享内存是一种最为高效的进程通信方式。因为
    发表于 10-18 16:08 1次下载
    <b class='flag-5'>进程</b><b class='flag-5'>间</b>通信之<b class='flag-5'>共享</b><b class='flag-5'>内存</b>

    你知道Linux共享内存与tmpfs文件系统是什么样?

    共享内存主要用于进程通信,Linux有两种共享内存
    发表于 05-04 17:33 2143次阅读
    你知道<b class='flag-5'>Linux</b>的<b class='flag-5'>共享</b><b class='flag-5'>内存</b>与tmpfs文件系统是什么样?

    Linux IPC System V 共享内存

    IPC_INFO(Linux-specific)返回系统对共享内存的限制写入到buf指向的时shminfo结构体中//_GNU_SOURCEstruct shminfo { u
    发表于 04-02 14:46 276次阅读

    深入剖析Linux共享内存原理

    不同进程之间进行通信,需要让不同进程共享相同的物理内存Linux通过  共享
    的头像 发表于 10-30 09:52 2278次阅读
    深入剖析<b class='flag-5'>Linux</b><b class='flag-5'>共享</b><b class='flag-5'>内存</b>原理

    Linux系统的共享内存的使用

    但有时候为了让不同进程之间进行通信,需要让不同进程共享相同的物理内存Linux通过 共享
    的头像 发表于 11-14 11:55 1315次阅读

    Linux进程共享内存通信时如何同步?

    今天我们来讲讲进程间使用共享内存通信时为了确保数据的正确,如何进行同步?
    的头像 发表于 05-11 18:25 1555次阅读

    Linux进程如何实现共享内存通信

    在上面的例程中,我们首先使用ftok()函数生成一个key值作为共享内存的标识符。然后使用shmget()函数创建共享内存区域,shmaddr指向
    发表于 06-19 09:55 634次阅读