首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

初识Linux · 共享内存

我们通过这个图,引出我们今日的话题: 在Linux中,万物皆是文件的概念已经深深的刻入到了我们的大脑里面,在文件系统里面我们介绍了进程,介绍了地址空间,介绍了页表,介绍了物理内存之间的映射关系,知道了代码和数据的地址通过页表...在Linux源码里面是有共享内存对应的结构体的,这里因为不介绍,所以不放出对应的源码了,肯定就有人说了,怎么又又又是结构体?...因为Linux就是C语言写的呀,并且,C语言想要对某个对象管理,结构体不是最好的选择吗? 所以我们得出一个结论,共享内存 = 共享内存的数据 + 共享内存的属性!!...对于第一种模式,IPC_CREAT,代表的是如果创建的共享内存不存在,就创建,如果存在共享内存,就获取该共享内存并返回,说白了就是总能够获取一个共享内存,但是不一定是全新的。...那么对于函数shmget的返回值的描述是: 返回的值如果成功了,返回的是共享内存的唯一标识符,如果开辟共享内存失败了,返回的就是就是-1。

8610
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Linux进程通信--共享内存

    首先由操作系统在物理内存中开辟一段内存空间,共享内存虽然是操作系统创建的,但是这些进程中的某一个需要来创建这个共享内存,这个共享内存属于操作系统的。...由此,操作系统就要对共享内存进程管理(先描述,再组织),共享内存不是简单的一段内存空间,也要有描述并管理共享内存的数据结构和匹配算法。简单来说,对共享内存的管理,就变成了对链表的增删查改。...总结一下: 共享内存=内存空间(数据)+共享内存的属性 共享内存的操作 创建共享内存函数接口 创建共享内存函数接口为:shmget #include #include 共享内存段的标识码;失败返回-1 形成key–fotk #include #include key_t ftok(...shmflg:它的两个可能取值是SHM_RND和SHM_RDONLY 返回值:失败返回0,成功返回地址空间中共享内存的起始地址。

    11610

    【Linux修炼】16.共享内存

    创建Key值如果失败,则返回-1。...返回值:成功返回一个非负整数,即该共享内存段的标识码;失败返回-1 shmat函数 功能:将共享内存段连接到进程地址空间 原型 void *shmat(int shmid, const void *shmaddr...,指向共享内存第一个节;失败返回-1 说明: shmaddr为NULL,核心自动选择一个地址 shmaddr不为NULL且shmflg无SHM_RND标记,则以shmaddr为连接地址。...(const void *shmaddr); 参数 shmaddr: 由shmat所返回的指针 返回值:成功返回0;失败返回-1 注意:将共享内存段与当前进程脱离,不等于删除共享内存段 shmctl函数...:将要采取的动作(有三个可取值),如下 buf:指向一个保存着共享内存的模式状态和访问权限的数据结构,一般设定为nullptr即可 返回值:成功返回0;失败返回-1 此外,关于最终的代码展示在如下链接

    4K00

    Linux进程间通信【共享内存】

    ,如果存在,则使用已经存在的 IPC_EXCL 避免使用已存在的共享内存,不能单独使用,需要配合 IPC_CREAT 使用,作用是当创建共享内存时,如果共享内存已经存在,则创建失败 权限 因为共享内存也是文件...当我们再次运行程序时,会出现下面这种情况: 服务端运行失败,原因是 shmget 创建共享内存失败,这是因为服务端创建共享内存时,传递的参数为 IPC_CREAT | IPC_EXCL,其中 IPC_EXCL...注定了当共享内存存在时,创建失败 而客户端只是单纯的获取共享内存,同时也只传递了 IPC_CREAT 参数,所以运行才会成功 综上所述,服务端运行失败的根本原因是 待创建的共享内存已存在,如果想要成功运行...0,失败返回 -1 参数1 int shmid 待控制的共享内存 id 参数2 int cmd 控制共享内存的具体动作,同样是位图 参数3 struct shmid_ds *buf 用于获取或设置所控制共享内存的数据结构...》 ---- 总结 以上就是本次关于 Linux 进程间通信之 共享内存 的全部内容了,共享内存 是所有 IPC 中最快的一种,因为它省去了很多不必要的 IO 操作,进程直接对话进程,效率极高,不过在狂飙的后果就是不安全

    40800

    速通 Linux 共享内存原理

    共享内存是一个非常有意思的话题,一方面共享内存避免了通讯过程中的内存复制问题,是 Linux IPC 通讯中效率最高的一种。...从使用方式上讲,Linux 提供了三种共享内存的方式,包括 Unix 味的 POSIX 和 SysV 接口,还提供了直接文件映射内存的 mmap。...本文尝试分别介绍 Linux 共享内存的基本原理,并做一个 “违背祖宗的决定”,如何在 Golang 中使用共享内存。...Golang 是通过通讯代替共享内存的优雅代表,下文仅做试验,不建议日常使用 mmap mmap 是 POSIX 规范中的文件映射内存的方法,Linux 并提供了同名系统调用。...总结 从原理上讲 Linux 共享内存的主要方式只有两种,一是基于文件的 mmap,另一种就是 tmpfs,用一张图描述 Linux 几种实现共享内存的方式:

    4.1K20

    Linux进程通信之共享内存

    Linux进程通信之共享存储 概念: 共享内存指 (shared memory)在多处理器的计算机系统中,可以被不同中央处理器(CPU)访问的大容量内存。...任何一个缓存的数据被更新后,由于其他处理器也可能要存取,共享内存就需要立即更新,否则不同的处理器可能用到不同的数据。...共享内存是 Unix下的多进程之间的通信方法 ,这种方法通常用于一个程序的多进程间通信,实际上多个程序间也可以通过共享内存来传递信息。...PHP中的封装: php中封装了shm开头的函数和shmop开头的函数,实际效果是一样的,具体使用方式请查看官方手册 ,下面我们以shm开头的为例演示 特点: 共享内存是将内存映射到其他进程的地址空间中...,所以说共享内存也是最快的IPC进程通信方式 前提: 在使用IPC进程通信时,也就是信号量、消息队列、共享存储时,首先要先确定自己的PHP扩展是否已经开启,使用php -m 查看 编写代码 父子进程

    4.8K31

    Linux进程间通信之共享内存

    一,共享内存   内核管理一片物理内存,允许不同的进程同时映射,多个进程可以映射同一块内存,被多个进程同时映射的物理内存,即共享内存。   映射物理内存叫挂接,用完以后解除映射叫脱接。...1,共享内存的特点: 优点:是最快的IPC。 缺点:要编程者自己实现对共享内存互斥访问。如何实现?...     3) 映射共享内存(得到虚拟地址), shmat()      4) 使用共享内存, 往共享内存中写入数据      5) 解除映射 shmdt()      6) 如果共享内存不再使用,可以使用...shmctl()销毁共享内存 进程B: readshm.c        1) 获得key, ftok()        2) 使用key来获得一个共享内存 shmget()        3) 映射共享内存...(得到虚拟地址), shmat()        4) 使用共享内存, 读取共享内存中的数据        5) 解除映射 shmdt()      3,实例 进程A: // writeshm.c

    4.4K50

    Linux 进程间通信 : 共享内存(上)

    前言 本文主要说明在Linux环境上如何使用共享内存。阅读本文可以帮你解决以下问题: 什么是共享内存和为什么要有共享内存? 如何使用mmap进行共享内存? 如何使用XSI共享内存?...Linux系统在编程上为我们准备了多种手段的共享内存方案。包括: mmap内存共享映射。 XSI共享内存。 POSIX共享内存。 下面我们就来分别介绍一下这三种内存共享方式。...XSI共享内存 为了满足多个无关进程共享内存的需求,Linux提供了更具通用性的共享内存手段,XSI共享内存就是这样一种实现。...之后我么好还需要确保共享内存的限制不会使我们申请失败: [root@zorrozou-pc0 sharemem]# echo 2147483648 > /proc/sys/kernel/shmmax [...接Linux进程间通信:共享内存 (下)

    11.3K33

    Linux进程间通信:共享内存 (下)

    接Linux进程间通信:共享内存 (上) POSIX共享内存 POSIX共享内存实际上毫无新意,它本质上就是mmap对文件的共享方式映射,只不过映射的是tmpfs文件系统上的文件。 什么是tmpfs?...Linux提供一种“临时”文件系统叫做tmpfs,它可以将内存的一部分空间拿来当做文件系统使用,使内存空间可以当做目录文件来用。...现在绝大多数Linux系统都有一个叫做/dev/shm的tmpfs目录,就是这样一种存在。具体使用方法,大家可以参考我的另一篇文章《Linux内存中的Cache真的能被回收么?》。...Linux提供的POSIX共享内存,实际上就是在/dev/shm下创建一个文件,并将其mmap之后映射其内存地址即可。...这部分内容大家也可以参考《Linux内存中的Cache真的能被回收么?》。

    8.3K12

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

    下面将讲解进程间通信的另一种方式,使用共享内存。 一、什么是共享内存 顾名思义,共享内存就是允许两个不相关的进程访问同一个逻辑内存。...有关信号量的更多内容,可以查阅我的另一篇文章: Linux进程间通信——使用信号量 二、共享内存的使得 与信号量一样,在Linux中也提供了一组函数接口用于使用共享内存,而且使用共享共存的接口还与信号量的非常相似...调用失败返回-1....调用成功时返回一个指向共享内存第一个字节的指针,如果调用失败返回-1. 3、shmdt函数 该函数用于将共享内存从当前进程中分离。...它的原型如下: int shmdt(const void *shmaddr); 参数shmaddr是shmat函数返回的地址指针,调用成功时返回0,失败时返回-1. 4、shmctl函数 与信号量的

    3.5K20

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

    共享内存的优势 采用共享内存通信的一个显而易见的好处是效率高,因为进程可以直接读写内存,而不需要任何数据的拷贝。...对于像管道和消息队列等通信方式,则需要在内核和用户空间进行四次的数据拷贝,而共享内存则只拷贝两次数据:一次从输入文件到共享内存区,另一次从共享内存区到输出文件。...Linux的2.6.x内核支持多种共享内存方式,如mmap()系统调用,Posix共享内存,以及System V共享内存。本文对3种共享内存形式都将进行介绍。...linux采用的是页式管理机制。...在Linux 2.6.x中,对于POSIX信号量和共享内存的名字会在/dev/shm下建立对应的路径名 [root@rocket shm]# ll /dev/shm/|grep mem -rwxr-xr-x

    7.2K61
    领券