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

简介: 【Linux】共享内存实现进程间通信

实现通信的原理:

       我们创建的每个进程都有自己的进程地址空间,但是这里面的数据的地址不是真正的数据的地址,真正的地址是在我们的物理内存上的

  共享内存实现通信就和他的名字一样,是共享的进程们都能够看的见,那这片内存当然也是开辟在物理内存上的,进程的进程地址空间 和 物理内存中间,存在一个页表,这个页表也就是帮我们实现地址转换的,同时也能起到解耦的作用。

     当我们两个进程的页表都与物理内存上的一片空间建立映射时,是不是也就让两个进程看到了同一份内存空间呢


shmget():

       我们要在物理内存中申请一片空间,还要让两个进程能够看见,那肯定需要一个特殊的值呐,当两个进程拿到同一个值的时候是不就有办法看到同一片资源,这个值为 key值

240c9d485b6a4fce826ce014edc9e053.jpg

        shmget()函数是一个申请共享内存的函数,给shmget()函数传入key值可以获得相应的IPC对象标识符,这里的 IPC对象标识符 和 IPC键值(key值) 是两个不同的东西,IPC对象标识符是建立在IPC键值之上的,我们产生的IPC键值就可以供我们后面的一些对共享内存进行函数使用


ftok():

ac9a2ad0e4f44242be40422f11f69fa8.jpg


   这个函数就是我们创建自己独一无二的 IPC键值 的函数 函数ftok把一个已存在的路径名和一个整数标识符转换成一个key_t值,称为IPC键值

   pathname:指定的文件,此文件必须存在且可存取

              proj_id: 自己设定的一个值,不能为0

       这个key值是根据你传的参数pathname和proj_id来形成的,操作系统会根据两者合成key值。


两个进程就可以传入同样的参数就可以获得相同的IPC键值,再使用shmget()函数访问到同一块内存空间片段。


key为IPC_PRIVATE,内核保证创建一个新的、唯一的IPC对象,IPC标识符与内存中的标识符不会冲突。
       IPC_PRIVATE为宏定义,其值等于0。
 


shmget()函数第二个参数 size:这个是申请的内存的大小

申请的空间大小也是建议以4kb的倍数申请,如果申请4300字节,那他会给你8000字节,但是你最终只能使用4300字节


shmget()函数第三个参数是我们申请空间时的权限设置

shmget()函数在使用时是可以设置权限的,IPC_CREAT 表示没有就创建,有就返回该对象。可如果加上IPC_EXCL那么没有就创建,有的话报错(errno=EEXIT)、ipc_perm中的mode的定义也会收到影响。最终的权限是由我们传的参数(0666)和它已有的mode或运算获得的  


shmat():

这个是用来与共享内存产生关联的函数 返回共享内存段的地址 ,申请完空间还应该与他关联起来才能访问

 void* shmat(int shmid(IPC键值),const void* shmaddr,int shmflag);

       第二个参数为nullptr表示为默认关联位置,第三个参数为0 表示默认为允许读写操作


shmdt():

shmdt()断开关联

       shmdt(const void* shmaddr);

这个参数需要传入 shmat()函数的返回的地址。


shmctl():

       这个函数是用来删除共享内存的,共享内存的生命周期是跟随内核的,即使有个进程退出了,它也是依旧存在的(可以在终端ipcs -m 查看是否存在;ipcrm -m shmid移除用shmid标识的共享内存段),如果不显示的删除,只能通过kernel(os)重启来解决。  

8f4f9685aa344a60ba8552b6f5fb020f.jpg

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

       第二个参数为nullptr表示为默认关联位置,第三个参数为0 表示默认为允许读写操作

目录
相关文章
|
21天前
|
算法 Linux 调度
深入理解Linux操作系统的进程管理
本文旨在探讨Linux操作系统中的进程管理机制,包括进程的创建、执行、调度和终止等环节。通过对Linux内核中相关模块的分析,揭示其高效的进程管理策略,为开发者提供优化程序性能和资源利用率的参考。
48 1
|
10天前
|
存储 监控 Linux
嵌入式Linux系统编程 — 5.3 times、clock函数获取进程时间
在嵌入式Linux系统编程中,`times`和 `clock`函数是获取进程时间的两个重要工具。`times`函数提供了更详细的进程和子进程时间信息,而 `clock`函数则提供了更简单的处理器时间获取方法。根据具体需求选择合适的函数,可以更有效地进行性能分析和资源管理。通过本文的介绍,希望能帮助您更好地理解和使用这两个函数,提高嵌入式系统编程的效率和效果。
64 13
|
11天前
|
运维 监控 Ubuntu
【运维】如何在Ubuntu中设置一个内存守护进程来确保内存不会溢出
通过设置内存守护进程,可以有效监控和管理系统内存使用情况,防止内存溢出带来的系统崩溃和服务中断。本文介绍了如何在Ubuntu中编写和配置内存守护脚本,并将其设置为systemd服务。通过这种方式,可以在内存使用超过设定阈值时自动采取措施,确保系统稳定运行。
29 4
|
17天前
|
SQL 运维 监控
南大通用GBase 8a MPP Cluster Linux端SQL进程监控工具
南大通用GBase 8a MPP Cluster Linux端SQL进程监控工具
|
24天前
|
C语言 开发者 内存技术
探索操作系统核心:从进程管理到内存分配
本文将深入探讨操作系统的两大核心功能——进程管理和内存分配。通过直观的代码示例,我们将了解如何在操作系统中实现这些基本功能,以及它们如何影响系统性能和稳定性。文章旨在为读者提供一个清晰的操作系统内部工作机制视角,同时强调理解和掌握这些概念对于任何软件开发人员的重要性。
|
21天前
|
算法 Linux
深入探索Linux内核的内存管理机制
本文旨在为读者提供对Linux操作系统内核中内存管理机制的深入理解。通过探讨Linux内核如何高效地分配、回收和优化内存资源,我们揭示了这一复杂系统背后的原理及其对系统性能的影响。不同于常规的摘要,本文将直接进入主题,不包含背景信息或研究目的等标准部分,而是专注于技术细节和实际操作。
|
23天前
|
Linux 调度 C语言
深入理解操作系统:从进程管理到内存优化
本文旨在为读者提供一次深入浅出的操作系统之旅,从进程管理的基本概念出发,逐步探索到内存管理的高级技巧。我们将通过实际代码示例,揭示操作系统如何高效地调度和优化资源,确保系统稳定运行。无论你是初学者还是有一定基础的开发者,这篇文章都将为你打开一扇了解操作系统深层工作原理的大门。
|
25天前
|
运维 监控 Linux
Linux操作系统的守护进程与服务管理深度剖析####
本文作为一篇技术性文章,旨在深入探讨Linux操作系统中守护进程与服务管理的机制、工具及实践策略。不同于传统的摘要概述,本文将以“守护进程的生命周期”为核心线索,串联起Linux服务管理的各个方面,从守护进程的定义与特性出发,逐步深入到Systemd的工作原理、服务单元文件编写、服务状态管理以及故障排查技巧,为读者呈现一幅Linux服务管理的全景图。 ####
|
1月前
|
缓存 算法 Linux
Linux内核的心脏:深入理解进程调度器
本文探讨了Linux操作系统中至关重要的组成部分——进程调度器。通过分析其工作原理、调度算法以及在不同场景下的表现,揭示它是如何高效管理CPU资源,确保系统响应性和公平性的。本文旨在为读者提供一个清晰的视图,了解在多任务环境下,Linux是如何智能地分配处理器时间给各个进程的。
|
29天前
|
存储 算法 安全
深入理解Linux内核的内存管理机制
本文旨在深入探讨Linux操作系统内核的内存管理机制,包括其设计理念、实现方式以及优化策略。通过详细分析Linux内核如何处理物理内存和虚拟内存,揭示了其在高效利用系统资源方面的卓越性能。文章还讨论了内存管理中的关键概念如分页、交换空间和内存映射等,并解释了这些机制如何协同工作以提供稳定可靠的内存服务。此外,本文也探讨了最新的Linux版本中引入的一些内存管理改进,以及它们对系统性能的影响。